千家信息网

LeetCode如何求数值的整数次方

发表于:2025-01-22 作者:千家信息网编辑
千家信息网最后更新 2025年01月22日,小编给大家分享一下LeetCode如何求数值的整数次方,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1,问题简述实现函数d
千家信息网最后更新 2025年01月22日LeetCode如何求数值的整数次方

小编给大家分享一下LeetCode如何求数值的整数次方,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

1,问题简述

实现函数double Power(double base, int exponent),求base的exponent次方。不得使用库函数,同时不需要考虑大数问题。

2,示例

示例 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.0n 是 32 位有符号整数,其数值范围是 [−231, 231 − 1] 。

3,题解思路

快速幂方法,java已有的api两种方法

4,题解程序


public class MyPowTest { public static void main(String[] args) { double x = 2.00000; int n = 10; double myPow = myPow(x, n); System.out.println("myPow = " + myPow); }
public static double myPow(double x, int n) { if (x == 0) { return 0; } if (n == 0) { return 1; } if (n > 0) { return pow(x, n); } else { return pow(1 / x, -n); } }
private static double pow(double x, int n) { if (n == 0) { return 1; } double r = pow(x, n / 2); if ((n & 1) == 1) { return r * r * x; } else { return r * r; } }}

5,题解程序图片版

以上是"LeetCode如何求数值的整数次方"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

0