《剑指offer》面试题16. 数值的整数次方
问题描述
实现函数double Power(double base, int exponent),求base的exponent次方。不得使用库函数,同时不需要考虑大数问题。
示例 1:
输入: 2.00000, 10
输出: 1024.00000
示例 2:
输入: 2.10000, 3
输出: 9.26100
示例 3:
输入: 2.00000, -2
输出: 0.25000
解释: 2-2 = 1/22 = 1/4 = 0.25
说明:
-100.0 < x < 100.0
n 是 32 位有符号整数,其数值范围是 [−231, 231 − 1] 。
代码1
class Solution {
public:
    double myPow(double x, int n) {
        if(x == 1 || x == 0)return x;
        int m = abs(n);
        double ans=1;
        while(m-- > 0)
        {
            ans *= x;
        }
        return n>0?ans:1/ans;
    }
};
结果错误
代码2
class Solution {
public:
    double myPow(double x, int n) {
        if(x == 1 || x == 0)return x;
        int m = abs(n);
        double ans=1;
        while(m > 0)
        {
            if(m % 2 == 1)
                ans *= x;
            x *= x;
            m /= 2;
        }
        return n>0?ans:1/ans;
    }
};
结果:
执行用时 :0 ms, 在所有 C++ 提交中击败了100.00%的用户
内存消耗 :5.9 MB, 在所有 C++ 提交中击败了100.00%的用户
代码3
class Solution {
public:
    double myPow(double x, int n) {
        if(n == 0)return 1;
        if(n < 0)return 1/myPow(x,-n);
        double ans = myPow(x,n/2);
        if(n % 2 == 0)
            return ans*ans;
        else
            return ans*ans*x;
    }
};
结果错误,测试中有边界值。。。
《剑指offer》面试题16. 数值的整数次方的更多相关文章
- 剑指Offer:面试题11——数值的整数次方(java实现)
		
题目描述: 实现函数double Power(double base, int exponent),求base的exponent次方,不得使用库函数,同时不需要考虑大数问题 思路:本题的重点考察内容是 ...
 - 剑指Offer - 九度1514 - 数值的整数次方
		
剑指Offer - 九度1514 - 数值的整数次方2013-11-30 00:49 题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponen ...
 - 剑指offer_面试题11 数值的整数次方_考察代码的完整性
		
测试通过代码: package t0825; public class Power { public static void main(String[] args){ System.out.print ...
 - 剑指offer(12)数值的整数次方
		
题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 题目分析 这道题用传统的方法也可以做,只不过效率太低,这里我们用到快速幂的方法 ...
 - 剑指offer十二之数值的整数次方
		
一.题目 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 二.思路 1.传统方法计算,时间复杂度O(n) 2.递归方式计算,时间复杂度O ...
 - 【剑指Offer】12、数值的整数次方
		
题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 解题思路: 本题看似比较简单,是一个简单的指数运算,但需要完 ...
 - 【剑指offer】面试题 16. 数值的整数次方
		
面试题 16. 数值的整数次方 题目描述 题目:给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 解答过程 下面的讨论中 x 代表 bas ...
 - 剑指offer——面试题16:数值的整数次方
		
// 面试题16:数值的整数次方 // 题目:实现函数double Power(double base, int exponent),求base的exponent // 次方.不得使用库函数,同时不需 ...
 - 剑指offer 面试题43. 1~n整数中1出现的次数
		
leetcode上也见过一样的题,当时不会做 看了一下解法是纯数学解法就没看,结果剑指offer上也出现了这道题,那还是认真看下吧 对于数字abcde,如果第一位是1,比如12345,即计算f(123 ...
 - C++版 - 剑指offer 面试题16:反转链表(Leetcode 206: Reverse Linked List) 题解
		
面试题16:反转链表 提交网址: http://www.nowcoder.com/practice/75e878df47f24fdc9dc3e400ec6058ca?tpId=13&tqId= ...
 
随机推荐
- 日程选项卡的设置(Project)
			
<Project2016 企业项目管理实践>张会斌 董方好 编著 在使用任何一个软件之前,都有一些默认的东东要改,比如在Excel里有人不待见单元格里的0,一定要设置成不显示零值:在Wor ...
 - Windows10计算文件SHA1 SHA256 SHA384 SHA512 or MD5
			
目录 Windows10计算文件SHA1 SHA256 SHA384 SHA512 or MD5? 1.计算SHA1 2.计算SHA256 3.计算SHA384 4.计算SHA512 5.计算MD5 ...
 - action中redirectAction到另一个命名空间中的action该如何配置
			
action中redirectAction到另一个命名空间中的action该如何配置,请注意namespace这儿必须是/global,而不是global,要不然找不到此action的
 - redis启动报错  var/run/redis_6379.pid exists, process is already running or crashed
			
redis启动显示 /var/run/redis_6379.pid exists, process is already running or crashed 出现这个执行 rm -rf /var/r ...
 - C/C++ 基本类型 占字节
			
下面给出不同位数编译器下的基本数据类型所占的字节数: 16位编译器 char :1个字节char*: 2个字节(即指针变量)short: 2个字节int: 2个字节unsigned int : 2个 ...
 - git 命令之暂存相关指令。
			
git 命令之暂存相关指令. 1.git 代码暂存指令:git stash 2.git 代码暂存列表信息:git stash list 3.git 代码应用暂存代码:git stash apply s ...
 - 【LeetCode】253. Meeting Rooms II 解题报告(C++)
			
作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 排序+堆 日期 题目地址:https://leetco ...
 - 【LeetCode】733. Flood Fill 解题报告(Python)
			
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 方法一:DFS 方法二:BFS 日期 题目地址:ht ...
 - 【LeetCode】831. Masking Personal Information 解题报告(Python)
			
[LeetCode]831. Masking Personal Information 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemingzh ...
 - Arm64架构下静态编译Nginx
			
这段时间,我一直忙于将 Rainbond 源码构建模块移植到 Arm64/aarch64 架构中.这一源码构建模块可以将指定代码仓库中包含的源码,拉取构建成为容器镜像,在各种容器平台中运行.目前支持的 ...