前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LintCode x的n次幂题目分析代码

LintCode x的n次幂题目分析代码

作者头像
desperate633
发布2018-08-22 12:21:54
4170
发布2018-08-22 12:21:54
举报
文章被收录于专栏:desperate633desperate633

题目

实现 pow(x,n)

注意事项

不用担心精度,当答案和标准输出差绝对值小于1e-3时都算正确

样例 Pow(2.1, 3) = 9.261 Pow(0, 1) = 0 Pow(1, 0) = 1

分析

二分法递归 详细见代码注释

代码

public class Solution {
    /**
     * @param x the base number
     * @param n the power number
     * @return the result
     */
    public double myPow(double x, int n) {

        // Write your code here
        if (x == 0) {
            return 0;
        }
        
        // base case: when n = 0, the result is 1;
        if (n == 0) {
            return 1;
        }
        
        /*
        递归的主体部分
        */
        
        // X^(-n) = X^(n + 1) * X
        // X^n = 1/(x^(-n))
        if (n < 0) {
            double ret = x * myPow(x, -(n + 1));
            return (double)1/ret;
        }
        
        // 将求pow对半分。再将结果相乘
        double ret = myPow(x, n / 2);
        ret = ret * ret;
        
        //如果有余数,再乘以x本身。
        if (n % 2 != 0) {
            ret = ret * x;
        }
        
        return ret;
    }
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017.03.16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 分析
  • 代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档