剑指 Offer 16. 数值的整数次方 -- 快速幂

2023-10-29

0 题目描述

leetcode原题:剑指 Offer 16. 数值的整数次方
在这里插入图片描述

1 快速幂解法

快速幂实际上是二分思想的一种应用。
二分推导: x n = x n / 2 × x n / 2 = ( x 2 ) n / 2 , x^{n}=x^{n / 2} \times x^{n / 2}=\left(x^{2}\right)^{n / 2}, xn=xn/2×xn/2=(x2)n/2, n / 2 n / 2 n/2 为整数, 则需要分为奇偶两种情况(设向下取整除 法符号为 " / / " / / " //" ) :
∘ \circ n n n 为偶数: x n = ( x 2 ) n / / 2 x^{n}=\left(x^{2}\right)^{n / / 2} xn=(x2)n//2;
∘ \circ n n n 为奇数: x n = x ( x 2 ) n / / 2 , x^{n}=x\left(x^{2}\right)^{n / / 2}, xn=x(x2)n//2, 即会多出一项 x x x;

算法流程:

  1. x = 0 x=0 x=0 时:直接返回 0 (避免后续 x = 1 / x x=1 / x x=1/x 操作报错 ) ) )
  2. 初始化 r e s = 1 \mathrm{res}=1 res=1;
  3. n < 0 n<0 n<0 时:把问题转化至 n ≥ 0 n \geq 0 n0 的范围内,即执行 x = 1 / x , n = − n x=1 / x, n=-n x=1/x,n=n;
  4. 循环计算:当 n = 0 n=0 n=0 时跳出
    1. n & 1 = 1 n \& 1=1 n&1=1 时:将当前 x x x 乘入 r e s ( r e s \quad( res( r e s ∗ = x ) r e s *=x) res=x);
    2. 执行 x = x 2 ( x=x^{2} \quad( x=x2( x ∗ = x ) x *=x) x=x);
    3. 执行 n n n 右移一位 (即 n > > = 1 n>>=1 n>>=1 ) 。
  5. 返回 r e s r e s res
class Solution:
    def myPow(self, x: float, n: int) -> float:
        if x == 0: return 0
        res = 1
        if n < 0: 
            x, n = 1 / x, -n
        while n:
            if n & 0x1: res *= x
            x *= x
            n >>= 1
        return res

递归解法:
(注意:0的0次方在数学上没有意义,而且0没有倒数)

class Solution:
    def myPow(self, x: float, n: int) -> float:
        if x == 0: return 0
        if n >= 0: 
            return self.power(x, n)
        return self.power(1/x, -n)
        
    def power(self, x: float, n: int):
        if n == 0: return 1
        r = self.power(x, n // 2)
        if n & 1:
            return r*r*x
        return r*r

复杂度分析:
时间复杂度: O ( log ⁡ 2 N ) O(\log _2 N) O(log2N) ,二分的时间复杂度为对数级别。
空间复杂度: O ( N ) O(N) O(N),递归写法有一个栈空间。

参考资料

面试题16. 数值的整数次方(快速幂,清晰图解)

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

剑指 Offer 16. 数值的整数次方 -- 快速幂 的相关文章

随机推荐

  • SpringClud Sleuth + Zipkin + Kafka实现分布式链路追踪

    SpringClud Sleuth Zipkin Kafka实现分布式链路追踪 使用步骤 使用步骤 1 导入 pom 依赖
  • 关于Spring Cloud Gateway 网关限流

    本文将使用以下两种方式实现网关的限流 使用 Spring Cloud Gateway 的 RequestRateLimiter 过滤器工厂基于 Redis 的限流 使用 Sentinel 结合 Spring Cloud Gateway 来实
  • vue动态组件component详解

    附上代码
  • 演唱会门票抢不到?不要慌,教你用python实现自动化抢票

    前言 之前有小伙伴留言说女朋友快生日了 喜欢某某某但是手动买票根本就是买不到 又不想当大冤种从黄牛手里加钱 于是乎在疯狂星期四的晚上遭到 贿赂 的我连夜搞定了 一丶安装环境和配置文件 要用python实现 下载和安装python自然是不用说
  • P1016 旅行家的预算【模拟+贪心】【详解】

    题目链接 思路 这道题是一道很明显的模拟题 但这道题也需要自己的理解 我自己写了些样例 然后找到了其中的模拟 我们假设从一个点出发 对于它的下一个点我们有很多选择 期间定义一个len用以记录满油 单次最远 到达距离 我们造访这条路上的所有点
  • MYSQL数据库(六)用户、权限管理和DCL语句

    成功不易 加倍努力 1 MySQL用户管理 2 权限管理和DCL语句 3 MySQL的图形化的远程管理工具 1 MySQL用户管理 元数据数据库 mysql 系统授权表 USERNAME HOST HOST 主机名 user1 web1 m
  • 区块链到底是怎么运行的

    为了方便你理解 这一篇文章我将以比特币为例来进行讲解 因为比特币算是区块链应用中最简单 最容易理解的一个案例了 中心化记账的问题 首先 举一个关于中心化记账的经典例子 银行转账 假设小明给小红转200块 银行收到了转账请求 将小明银行账户里
  • 区块链hyperledger fabric架构详解

    hyperledger fabric是区块链中联盟链的优秀实现 主要代码由IBM Intel 各大银行等贡献 目前v1 1版的kafka共识方式可达到1000 s次的吞吐量 本文中我们依次讨论 区块链的共通特性 fabric核心概念 fab
  • vue全局一个格式化时间-format

    vue圈定定义一个format 用来格式化时间 Date prototype format function fmt const o M this getMonth 1 月份 d this getDate 日 h this getHours
  • Sudo: unable to initialize policy plugin 解决方法

    在centos7下 使用sudo 命令对www用户生成ssh秘钥 结果报错如下 Sudo parse error in etc sudoers near line 125 Sudo no valid sudoers sources foun
  • OS - 操作系统实战 - 学习/实践

    1 应用场景 主要用于学习 设计和编写操作系统 同时帮助更加好低理解操作系统 研究Linux系统 提供编程能力 2 学习 操作 1 文档阅读 操作系统实战45讲 操作系统 Linux 计算机基础 底层 内核 后端开发 iOS 彭东 C语言
  • c++中string的substr函数

    在 C 中 substr 函数用于提取字符串的子串 它有两种常用的用法 1 substr pos len 提取从位置 pos 开始的长度为 len 的子串 pos 指定提取子串的起始位置 位置从 0 开始 len 指定提取子串的长度 如果不
  • 2019年3月web前端最新面试题

    最近在找工作 面试了好多家公司 结果都不怎么理想 要么公司环境氛围不行 要么工资达不到理想的薪资 大部分公司对程序员的面试流程几乎都一样 来了先填一份登记表 写一套面试题 然后技术面 人事面 至于有的大牛说 四面web前端 拿到10K 的工
  • js 搜索关键字高亮

    主要是通过replace方法实现的 实现代码
  • SSTI 学习笔记

    PHP SSTI Twig 学习文章 进入环境 左上角有flag hint 都检查看看 flag页面显示ip hint页面源代码有提示 考虑XFF头或者referer头 测试一下 注 这里不用加上 出来了 python flask ssti
  • 30岁之后想转行,可行吗?这20条建议让你少走弯路!

    都说三十而立 可眼看着到了意气风发的年龄 却突然意识到自己仍一事无成 甚至连养活自己都是问题 30多岁 大多数人还要开始买房 买车 结婚生子 养家糊口 于是各种压力逼迫之下 就想到了转行 期望可以通过转行实现 财务自由 不过 俗话说 隔行如
  • 函数strlen的使用

    函数strlen是C语言的提供的函数 它包含在 include
  • Linux命令_printf & 格式化输出信息

    目录 1 语法 1 1 格式化参数 1 2 转义符参数 2 常见用法 2 1 输出字符串 2 2 格式化输出 2 3 设置格式对齐 2 4 控制输出宽度 2 5 替换补全字符 3 设置颜色 3 1 参数选项 3 2 基本用法 3 3 设置文
  • java选择排序(Selection Sort)——详解讲解+案例+时间复杂度

    文章目录 需求 排序原理 案例 选择排序的时间复杂度分析 需求 排序前 4 6 8 7 9 2 10 1 排序后 1 2 4 5 7 8 9 10 排序原理 1 每一次遍历的过程中 都假定第一个索引处的元素是最小值 和其他索引处的值依次进行
  • 剑指 Offer 16. 数值的整数次方 -- 快速幂

    0 题目描述 leetcode原题 剑指 Offer 16 数值的整数次方 1 快速幂解法 快速幂实际上是二分思想的一种应用 二分推导 x n x n