算法题每日一练---第62天:Pow(x, n)

简介: 实现 pow(x, n) ,即计算 x 的 n 次幂函数(即,x^n)

4.png

一、前言

实现 pow(x, n) ,即计算 xn 次幂函数(即,x^n)。


题目链接:Pow(x, n)


二、题目要求


样例 1

输入: x = 2.00000, n = 10
输出: 1024.00000


样例 2

输入: x = 2.10000, n = 3
输出: 9.26100


考察

位运算中等题型、快速幂
建议用时15~30min


三、问题分析

本题是位运算的第17题,没了解过位运算相关知识点可以看这一篇文章,讲解比较详细:

算法题每日一练---第45天:位运算


如果你了解过位运算相关知识点,但没有了解过快速幂,可以先看这一篇

算法题每日一练---第60天:快速幂


这一题其实套用位运算的模板就行了,最主要的是n的范围 -23^1 <= n <= 2^31-1,这不正好是int整形存储二进制的范围吗?


这里要注意一点,因为n有可能小于0,对于这种情况我们还是按照正数判断,最后取倒数就行了。


最后提交测试的时候,发现了几个恶心的测试用例怎么也过不了

22.png


最后我修改了题目给定的n,从int 改成long然后就莫名其妙的过了。

21.png


四、编码实现


classSolution {
public:
doublemyPow(doublex, longn) {
intflag=1;//判断n负数的标记doublebase=x,ans=1;//初始化if(n<0)
        {
flag=0;
n=abs(n);//取正数        }
while(n)//快速幂模板        {
if(n&1)
ans=ans*base;
base*=base;
n=n>>1;
        }
if(flag)//正数输出结果returnans;
else//取倒数输出return1.0*1/ans;
    }
};

五、测试结果

20.png

六、总结与提高

这一题是位运算分支的第17题,是快速幂的第2题。快速幂掌握其实不难,在网上找了半天,发现2个典型的快速幂运算,这两题做完快速幂也能基本掌握了。

相关文章
|
2月前
|
算法 Java 程序员
【算法每日一练及解题思路】有n级台阶,一次只能上1级或2级,共有多少种走法?
本文深入解析了“爬楼梯问题”,探讨了递归与迭代两种解法,并提供了Java代码实现。通过分析问题本质,帮助读者理解动态规划技巧,提高解决实际编程问题的能力。关键词:Java, 算法, 动态规划, 爬楼梯问题, 递归, 迭代。
116 0
|
算法
算法题每日一练---第78天:二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target
200 1
算法题每日一练---第78天:二分查找
|
存储 算法
|
算法
算法题每日一练---第76天:丑数 l
丑数 就是只包含质因数 2、3 和 5 的正整数。
156 1
算法题每日一练---第76天:丑数 l
|
算法
算法题每日一练---第75天:Nim 游戏
你和你的朋友,两个人一起玩 Nim 游戏。
331 0
算法题每日一练---第75天:Nim 游戏
|
算法
算法题每日一练---第74天:快乐数
编写一个算法来判断一个数 n 是不是快乐数。
186 0
算法题每日一练---第74天:快乐数
|
存储 算法
算法题每日一练---第73天:加一
给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。
168 0
算法题每日一练---第73天:加一
|
算法
算法题每日一练---第72天:数字 1 的个数
给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数。
237 0
算法题每日一练---第72天:数字 1 的个数
|
存储 算法
算法题每日一练---第71天:回文数
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
166 0
算法题每日一练---第71天:回文数