LeetCode-050-Pow(x, n)
Pow(x, n)
题目描述:实现 pow(x, n) ,即计算 x 的 n 次幂函数(即,)。
示例说明请见LeetCode官网。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/powx-n/
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解法一:递乘/递除法
首先,如果x的值等于1,因为1的任意次方结果都是1,所以直接返回1;如果x的值不等于1,则可以分以下几种情况进行处理,分别是n为0、n大于0、n小于0的情况,处理过程如下,用result记录临时结果:
- 当n的值等于0的时候,因为任何数的0次方结果都为1,所以直接返回1;
- 当n的值大于0的时候,首先将result的值初始化为x,然后将result乘以x并且乘n-1次,最后返回result的值;
- 当n的值小于0的时候,首先将n设置为n的绝对值,然后将result初始化为1,然后将result除以x除n次,最后返回result的值。
当n的值大于0或者小于0的时候,实际上可以用同一种方式处理,因为当n小于0的时候,可以将n取绝对值后,然后将x自乘n次,然后用1除以这个自乘结果也可以得到最终结果。
解法二:调用库函数
调用jdk自带的库函数
Math.pow(x, n)
返回结果。虽然能够提交成功,但是这是很投机的做法,不可取。
public class LeetCode_050 {
/**
* 方法一:递乘/递除
*
* @param x
* @param n
* @return
*/
public static double myPow(double x, int n) {
if (x == 1) {
return 1;
}
double result = x;
if (n == 0) {
result = 1;
} else if (n > 0) {
for (int i = 1; i < n; i++) {
result *= x;
}
} else {
n = Math.abs(n);
result = 1;
for (int i = 0; i < n; i++) {
result /= x;
if (result < Double.MIN_VALUE) {
return 0;
}
}
}
return result;
}
/**
* 方法二:调用库函数
*
* @param x
* @param n
* @return
*/
public static double myPow2(double x, int n) {
return Math.pow(x, n);
}
public static void main(String[] args) {
System.out.println(myPow(2.0000, -48));
}
}
【每日寄语】 每个充满希望的清晨,告诉自己努力,是为了遇见更好的自己。
分类:
LeetCode-个人题解
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了