原创博文,转载请注明出处!

1.题目

      给定一个double类型的浮点数base和int类型的整数exponent,求base的exponent次方。注意:不得使用库函数,同时不需要考虑大数问题。
 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++实现(递归)的更多相关文章

  1. 剑指 Offer 16. 数值的整数次方

    实现函数double Power(double base, int exponent),求base的exponent次方.不得使用库函数,同时不需要考虑大数问题. 来源:力扣(LeetCode) 链接 ...

  2. 《剑指offer》 数值的整数次方

    本题来自<剑指offer> 数值的整数次方 题目: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 思路: 代码从三个方面处 ...

  3. 【剑指Offer】数值的整数次方 解题报告(Python)

    [剑指Offer]数值的整数次方 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https://www.nowcoder.com/ta/coding-interviews ...

  4. 【Java】 剑指offer(15) 数值的整数次方

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 实现函数double Power(double base, int ...

  5. (3)剑指Offer之数值的整数次方和调整数组元素顺序

    一 数值的整数次方 题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 问题解析: 这道题算是比较麻烦和难一点的一个了.我这里采 ...

  6. 【剑指offer】数值的整数次方

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/mmc_maodun/article/details/25506085 转载请注明出处:http:// ...

  7. Go语言实现:【剑指offer】数值的整数次方

    该题目来源于牛客网<剑指offer>专题. 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 保证base和exponent不 ...

  8. 剑指OFFER之数值的整数次方(九度OJ1514)

    题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 输入: 输入可能包含多个测试样例.对于每个输入文件,第一行输入一个整数T,表 ...

  9. 剑指Offer 12. 数值的整数次方 (其他)

    题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 题目地址 https://www.nowcoder.com/practice/ ...

  10. 剑指offer:数值的整数次方

    题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 解题思路: 一开始直接用一个for循环做连乘,测了一下,发现这个指数可能是负 ...

随机推荐

  1. 安装xenserver6.5

    安装之前的准备工作就不在赘述了,下边开始安装 1.安装界面 2.键盘模式选择默认-美式,ok 3.这里提醒你安装将清除磁盘信息,做好备份,选择ok. 4.这一步没有选择,要么继续,要么退回,选择Acc ...

  2. BZOJ4765: 普通计算姬

    BZOJ4765: 普通计算姬 题目描述 传送门 题目分析 求的和非常奇怪,不具有连续性,所有上树的数据结构全死了. 考虑分块,思考对于一段连续的询问区间可以直接询问整块,零散块可以在树上dfs序暴力 ...

  3. Nodejs V8引擎 fast property lookup

    前言 之所以会研究这个东西,是我在网上找了一下各个语言的执行效率比较.好吧,我承认这是个无聊的东西,不过看看总是无妨,然而我惊讶的发现,有些测试声称Java,C,Nodejs是处在同一个效率级别参见链 ...

  4. HDFS读写流程learning

    有许多对流程进行描述的博客,但是感觉还是应当学习一遍代码,不然总感觉怪怪的,https://blog.csdn.net/popsuper1982/article/details/51615285,首先 ...

  5. webjars-jquery的引用

    什么是WebJars WebJars以jar包的形式来使用前端的各种框架.组件,如jquery.bootstrap WebJars将客户端(浏览器)资源(JavaScript,Css等)打成jar包文 ...

  6. 拉取代码过程中遇到的:post install error,please remove node_modules before retry!

    这是在git → clone 之后,安装npm intall时出现的错误,完整错误提示如下: 解决: // 1.先删除node_modules这个文件 $ rm -rf node_modules/ / ...

  7. Memcached stats slabs 命令

    Memcached stats slabs 命令用于显示各个slab的信息,包括chunk的大小.数目.使用情况等. 语法: stats slabs 命令的基本语法格式如下: stats slabs ...

  8. 如何使移动web页面禁止横屏?

    https://segmentfault.com/q/1010000005813183 一般只有移动版有这种需求,我们一般不去禁止,而是比例缩放,css实现,竖屏1rem = 9pt ,横屏1rem ...

  9. spring mvc: 生成RSS源

    spring mvc: 生成RSS源 准备: 从相同的maven存储库页面下载 Rome 库及其依赖项rome-utils,jdom和slf4j.和所需的依赖关系 <!-- rss源依赖 --& ...

  10. 论Sava(),SaveOrUpdate(),Merge()区别

    一.Save(): 用于将一个临时对象转变为持久化对象,也就是将一个新的业务实体保存到数据库中:相当于jdbc的insert. <假如两个实体之间有关系(例如employee表和address表 ...