【剑指offer-16】数值的整数次方,C++实现(递归)
原创博文,转载请注明出处!
1.题目
class Solution {
public:
double Power(double base, int exponent) {
}
};
2.思路
# 解题思路(分情况讨论)
- 无效输入:base=0,exponent<0时,错误输入,输出为0并设置全局变量InvalidInput=true。
- 无效输入:base=0,exponent=0时,无效错误,数学上无意义,输出为0和1均可,程序中设置为1。
- 有效输入:exponent > 0时,直接计算;exponent < 0,指数取绝对值计算result,最后result去倒数。
①当程序中出现错误时,三种错误处理方式(异常、返回值、全局变量)的优缺点。

②判断两个浮点数是否相等
// 判断两个浮点数是否相等
bool Equal(double num1,double num2)
{
if((num1-num2) > -0.0000001 && (num1-num2)<0.0000001)
return true;
else
return false;
}
③以时间复杂度O(logn)计算指数
// 以时间复杂度O(logn)求整数的指数(递归)
double WithUnsignedExponent(double base,unsigned int exponent)
{
if(exponent == 0)
return 1; if(exponent == 1)
return base; // 递归计算指数
double result = WithUnsignedExponent(base,exponent>>1); // 指数是奇数或偶数
if(exponent & 1 == 1)
{
result *= result;
result *= base;
}
else
{
result *= result;
} return result;
}
3.code
#include <iostream>
using namespace std; // 全局变量:标识无效输入
bool InvalidInput = false; class Solution {
public:
double Power(double base, int exponent)
{
InvalidInput = false; // 无效输入:底数是零,指数是负数
if(Equal(base,0.0) && exponent < 0)
{
InvalidInput = true;
return 0.0;
} // 指数为正和指数为负,分类处理
double res = 0.0;
if(exponent < 0)
res = 1.0/WithUnsignedExponent(base,-exponent);
else
res = WithUnsignedExponent(base,exponent);
return res;
} // 判断两个浮点数是否相等
bool Equal(double num1,double num2)
{
if((num1-num2) > -0.0000001 && (num1-num2)<0.0000001)
return true;
else
return false;
} // 以时间复杂度O(logn)求整数的指数(递归)
double WithUnsignedExponent(double base,unsigned int exponent)
{
// 特殊情况
if(exponent == 0)
return 1; if(exponent == 1)
return base; // 递归计算指数
double result = WithUnsignedExponent(base,exponent>>1); // 指数是奇数或偶数
if(exponent & 1 == 1)
result = result * result * base;
else
result = result * result; return result;
}
}; int main()
{
Solution solution;
double base = 0.0;
int exponent = 0;
cout<<solution.Power(base,exponent)<<endl;
return 0;
}
4.复杂度
时间复杂度O(logn)
5.测试用例
底数为正数,负数,零
指数为正数,负数,零
【剑指offer-16】数值的整数次方,C++实现(递归)的更多相关文章
- 剑指 Offer 16. 数值的整数次方
实现函数double Power(double base, int exponent),求base的exponent次方.不得使用库函数,同时不需要考虑大数问题. 来源:力扣(LeetCode) 链接 ...
- 《剑指offer》 数值的整数次方
本题来自<剑指offer> 数值的整数次方 题目: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 思路: 代码从三个方面处 ...
- 【剑指Offer】数值的整数次方 解题报告(Python)
[剑指Offer]数值的整数次方 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https://www.nowcoder.com/ta/coding-interviews ...
- 【Java】 剑指offer(15) 数值的整数次方
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 实现函数double Power(double base, int ...
- (3)剑指Offer之数值的整数次方和调整数组元素顺序
一 数值的整数次方 题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 问题解析: 这道题算是比较麻烦和难一点的一个了.我这里采 ...
- 【剑指offer】数值的整数次方
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/mmc_maodun/article/details/25506085 转载请注明出处:http:// ...
- Go语言实现:【剑指offer】数值的整数次方
该题目来源于牛客网<剑指offer>专题. 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 保证base和exponent不 ...
- 剑指OFFER之数值的整数次方(九度OJ1514)
题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 输入: 输入可能包含多个测试样例.对于每个输入文件,第一行输入一个整数T,表 ...
- 剑指Offer 12. 数值的整数次方 (其他)
题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 题目地址 https://www.nowcoder.com/practice/ ...
- 剑指offer:数值的整数次方
题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 解题思路: 一开始直接用一个for循环做连乘,测了一下,发现这个指数可能是负 ...
随机推荐
- jackson序列化字段字母大小写及字段名重复
一:Jackson默认的属性发现规则将会查找到如下所述的属性: 1.所有被public修饰的字段(成员变量): 2.所有被public修饰的getter(即形如“getXxx()”的方法): 3.所有 ...
- vue集成ueditor
相关代码见github 1.引入ueditor相关的文件,具体目录见下图如下 我将下载的文件放在static下面,这里专门用来放置相关的静态文件 (在ueditor.config.js需要配置一下路径 ...
- PAT1071. Speech Patterns (25)
题目要求的Word定义 Here a "word" is defined as a continuous sequence of alphanumerical characters ...
- Asp.Net MVC 请求原理分析
分析Asp.Net MVC的请求过程,我们从以下几方面看: 配置:IIS网站的配置可以分为两个块:全局 Web.Config 和本站 Web.Config . Asp.Net Routing属于全局性 ...
- 浏览器检测-js
昨天有一同学问我为什么attachEvent在非IE浏览器下不能起作用,我也跟他解释了一番:attachEvent是IE下独有的,只能在IE下使用,其他浏览器下应该用addEventListener来 ...
- 修改Pycharm for Mac背景色
Mac 上面的Pycharm的背景是白色,太刺眼,网上教程那么多,实用性都不高,最终在csdn找到了一个. 修改步骤如下: pycharm -->Preferences --> Appea ...
- 【Python】偏函数
此文转载自廖雪峰. Python的functools模块提供了很多有用的功能,其中一个就是偏函数(Partial function).要注意,这里的偏函数和数学意义上的偏函数不一样. 在介绍函数参数的 ...
- 探究JS中的连等赋值问题
一.引子 最近在看别人的博客时无意中看到一个这样的问题 var a = {n: 1}; var b = a; a.x = a = {n:2}; console.log(a.x); //undefine ...
- hdu3549
题解: 网络流模板题 多组数据 代码: #include<cstdio> #include<cstring> #include<algorithm> #includ ...
- 使用minidom来处理XML的示例
http://www.cnblogs.com/xuxm2007/archive/2011/01/16/1936610.html http://blog.csdn.net/ywchen2000/arch ...