当前位置: 首页 > ops >正文

剑指offer15_数值的整数次方

数值的整数次方


实现函数 double Power(double base, int exponent)

题目要求

计算 base exponent \text{base}^{\text{exponent}} baseexponent

  • 不得使用库函数
  • 不需要考虑大数问题,绝对误差不超过 10 − 2 10^{-2} 102
  • 不会出现底数和指数同为 0 的情况
  • 当底数为 0 时,指数一定为正
  • 底数绝对值不超过 10,指数范围 [ − 2 31 , 2 31 − 1 ] [-2^{31}, 2^{31}-1] [231,2311]
样例1
输入:10 ,2输出:100
样例2
输入:10 ,-2  输出:0.01

算法思路
  1. 处理指数为 0 的情况:直接返回 1.0。
  2. 处理负指数
    • 将负指数转换为正数处理
    • 使用 long long 存储指数,避免 INT_MIN 取绝对值时溢出
    • 最终结果取倒数
  3. 快速幂算法
    • 初始化结果 res = 1.0
    • 循环处理指数(二进制分解):
      • 若当前二进制位为 1,则乘上当前底数
      • 底数平方,指数右移一位
    • 若底数变为 0,提前终止循环(避免后续无效计算)
  4. 处理负指数结果:返回 1.0/res
时间复杂度
  • O(log⁡n):每次迭代将指数减半
关键点
  • 负指数处理:转换为正数计算后取倒数
  • 大指数处理:使用 long long 避免溢出
  • 浮点精度:当底数平方下溢为 0 时提前终止
  • 边界情况:底数为 0 时直接返回 0(指数为正)
C++ 实现
class Solution {
public:double Power(double x, int n) {typedef long long ll;double res = 1;bool im = n < 0;for(ll k = abs(ll(n)); k; k >>= 1){if(k & 1) res *= x;x *= x;}if(im) res = 1 / res;return res;}
};
http://www.xdnf.cn/news/10835.html

相关文章:

  • 酷狗概念版4.1.6深度体验:探索音乐新境界的便捷之选
  • 网络原理1
  • 《对象创建的秘密:Java 内存布局、逃逸分析与 TLAB 优化详解》
  • MeloTTS中文发音人训练
  • CUDA与venv的配置
  • 【机器学习及深度学习】机器学习模型的误差:偏差、方差及噪声
  • vue2上传图片
  • matlab实现求解兰伯特问题
  • Filebeat技术之多行采集
  • java-spring
  • Blinko智能笔记系统实现跨平台同步与隐私保护的完整技术方案解析
  • 2025年MathorCup数学建模D题短途运输货量预测及车辆调度问题解题文档与程序
  • dataX(入门,mysql到doris)
  • 软件评测师 案例真题笔记
  • RDMA简介1之RDMA开发必要性
  • Java 中执行命令并使用指定配置文件的最佳实践
  • [蓝桥杯]生物芯片
  • 今日主题二分查找(寻找峰值 力扣162)
  • 初识小智AI项目
  • 酵母杂交那些事儿(一)
  • [Python] struct.unpack() 用法详解
  • 在 Linux 上安装 Nmap 工具
  • CSRF攻击与防御
  • 现代密码学介绍
  • 前端开发处理‘流式数据’与‘非流式数据’,在接收完整与非完整性数据时应该如何渲染和使用
  • 【产品研究】安克创新公司产品研究
  • 推荐算法八股
  • STM32外部中断(EXTI)以及旋转编码器的简介
  • 【深度学习-Day 22】框架入门:告别数据瓶颈 - 掌握PyTorch Dataset、DataLoader与TensorFlow tf.data实战
  • MongoTemplate常用api学习