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如何求数值的整数次方

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

原创文章,作者:3628473679,如若转载,请注明出处:https://blog.ytso.com/223706.html

(0)
上一篇 2022年1月7日
下一篇 2022年1月7日

相关推荐

发表回复

登录后才能评论