LeetCode第50题Pow(x, n)

国庆放假结束一周了,收心,开始学习技术啦。

继续打卡算法题,今天学习的是LeetCode第50题Pow(x, n),这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

实现幂函数pow(m,n)的功能,需要回顾下幂函数的定义,负指数幂等于对应正指数幂的倒

在Java中提供了库函数java.lang.Math#pow,但是本题是算法解题,肯定不适合使用库函数。那要如何求解呢?

初一看,我们肯定可以想到使用for循环,循环n次,不断的相乘得到结果。这样的肯定是可以求解的,有没有效率更高的呢?

以pow(3,4) 为例子,我们推算下朴素的计算过程

上面的图是从1次幂开始算的,一直算到指定次幂,如果我们使用分而治之的思考下,求3^4的时候,先算出3^2,那么3^4 = 3^2 * 3^2, 这样效率是不是提升了呢?

如果遇到n是奇数的情况,我们多需要乘一个m。

比如求3^5 = 3^2 * 3^2 * 3

本题解题技巧

1、需要理解幂函数的定义,特别是负指数幂的情况

2、分而治之思维,二分法思维,先求部分解,再求整体解。

编码解决

java 复制代码
class Solution {
    public double myPow(double x, int n) {
    long N = n;
        return N >= 0 ? quickMul(x, N) : 1.0 / quickMul(x, -N);
    }

    public double quickMul(double x, long N) {
        // 指数是奇数的情况 累加x
        double ans = 1.0;
        
        double x_contribute = x;
        
        while (N > 0) {
            //指数是奇数,额外计算一次底数
            if (N % 2 == 1) {
                // 如果 N 
                ans *= x_contribute;
            }
            // 每二分一次,就需要平方一次
            x_contribute *= x_contribute;
            // 二分一次
            N /= 2;
        }
        return ans;
    }
}

总结

本题考察的是分而治之的思想,先求解部分的解,整体的解可以通过部分的解得到,大大提高算法效率。

相关推荐
chenziang12 分钟前
leetcode hot 100 二叉搜索
数据结构·算法·leetcode
lvbu_2024war011 小时前
MATLAB语言的网络编程
开发语言·后端·golang
问道飞鱼1 小时前
【Springboot知识】Springboot进阶-实现CAS完整流程
java·spring boot·后端·cas
single5941 小时前
【c++笔试强训】(第四十五篇)
java·开发语言·数据结构·c++·算法
Q_19284999061 小时前
基于Spring Boot的电影网站系统
java·spring boot·后端
豌豆花下猫2 小时前
Python 潮流周刊#83:uv 的使用技巧(摘要)
后端·python·ai
凡人的AI工具箱2 小时前
每天40分玩转Django:Django部署概述
开发语言·数据库·后端·python·django
SomeB1oody2 小时前
【Rust自学】7.2. 路径(Path)Pt.1:相对路径、绝对路径与pub关键字
开发语言·后端·rust
SomeB1oody2 小时前
【Rust自学】7.3. 路径(Path)Pt.2:访问父级模块、pub关键字在结构体和枚举类型上的使用
开发语言·后端·rust
呆头鹅AI工作室2 小时前
基于特征工程(pca分析)、小波去噪以及数据增强,同时采用基于注意力机制的BiLSTM、随机森林、ARIMA模型进行序列数据预测
人工智能·深度学习·神经网络·算法·随机森林·回归