力扣每日一题50:Pow(x,n)

题目描述:

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

示例 1:

复制代码
输入:x = 2.00000, n = 10
输出:1024.00000

示例 2:

复制代码
输入:x = 2.10000, n = 3
输出:9.26100

示例 3:

复制代码
输入:x = 2.00000, n = -2
输出:0.25000
解释:2-2 = 1/22 = 1/4 = 0.25

提示:

  • -100.0 < x < 100.0
  • -231 <= n <= 231-1
  • n 是一个整数
  • 要么 x 不为零,要么 n > 0
  • -104 <= xn <= 104

通过次数

403.5K

提交次数

1.1M

通过率

38.0%

解题思路:

用一次一次的乘法的话,当n再2^31-1附近的时候,会超时,而且还要考虑int类型最小值加绝对值后会超过int类型的问题。在这里用递归的方法。再n大于零的情况下,当n为奇数时pow(x,n)=pow(x,n/2)*x;当n为偶数时pow(x,n)=pow(x,n/2),n==0时返回1。n小于零的情况下就算1.0/pow(x,-n)。

代码:

复制代码
class Solution {
public:
    double mulit(double x,long long n)
    {
        if(n==0) return 1.0;
        double y=mulit(x,n/2);
        return n%2==0?y*y:x*y*y;
    }
    double myPow(double x, int n) {
        long long N=n;
        double ans=N>=0?mulit(x,N):1.0/mulit(x,N);
        return ans;
    }
};
相关推荐
高山上有一只小老虎10 分钟前
字符串字符匹配
java·算法
愚润求学43 分钟前
【动态规划】专题完结,题单汇总
算法·leetcode·动态规划
林太白1 小时前
跟着TRAE SOLO学习两大搜索
前端·算法
ghie90901 小时前
图像去雾算法详解与MATLAB实现
开发语言·算法·matlab
云泽8081 小时前
从三路快排到内省排序:探索工业级排序算法的演进
算法·排序算法
weixin_468466852 小时前
遗传算法求解TSP旅行商问题python代码实战
python·算法·算法优化·遗传算法·旅行商问题·智能优化·np问题
·白小白2 小时前
力扣(LeetCode) ——43.字符串相乘(C++)
c++·leetcode
FMRbpm2 小时前
链表5--------删除
数据结构·c++·算法·链表·新手入门
程序员buddha3 小时前
C语言操作符详解
java·c语言·算法
John_Rey3 小时前
API 设计哲学:构建健壮、易用且符合惯用语的 Rust 库
网络·算法·rust