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

Leetcode 50. Pow(x, n)

文章目录

  • 题目
  • 代码(9.19 首刷看解析)

题目

在这里插入图片描述
Leetcode 50. Pow(x, n)

代码(9.19 首刷看解析)

快速幂

class Solution {
public:double myPow(double x, int n) {if(n == 0)return 1;if(n == 1)return x;if(n == INT_MIN) {  // 避免-n整形溢出return myPow(1/x, -(n+1))/x;}if(n < 0) {return myPow(1/x, -n);}if(n % 2) {return (x*myPow(x, n-1));} else {double sub = myPow(x, n/2);return (sub*sub);}}
};

另一种解法

class Solution {
public:double myPow(double x, int n) {if(n == INT_MIN) {  // 避免-n整形溢出return myPow(1/x, -(n+1))/x;}if(n < 0) {return myPow(1/x, -n);}double ans = 1, tmp = x;while(n != 0) {if(n & 1 != 0) {ans = ans*tmp;}n>>=1;tmp = tmp*tmp;}return ans;}
};
http://www.lryc.cn/news/174459.html

相关文章:

  • hive分区表的元数据信息numRows显示为0
  • Baumer工业相机堡盟工业相机如何通过BGAPI SDK设置相机的图像剪切(ROI)功能(C++)
  • 【云原生】聊聊为什么需要docker以及其基础架构
  • “高级前端开发技术探索路由的使用及Node安装使用“
  • LeetCode 494.目标和 (动态规划 + 性能优化)二维数组 压缩成 一维数组
  • [36c3 2019]includer
  • Python150题day10
  • Autosar工具-Davinci Developer
  • js中的数据结构:栈,队列,链表,字典哈希表,树
  • Verdi实现信号的平移
  • Leetcode算法入门与数组丨6. 数组双指针、滑动窗口
  • 推荐一本书《横向领导力》
  • React实战过程的知识了解
  • F对象和Q对象
  • Visio——绘制倾斜线段
  • Linux复习-安装与熟悉环境(一)
  • Go基础语法:map
  • 开发板TFTP调试
  • MySQL---优化日志
  • 【送面试题】深入解析Cookie和Session的请求区别及使用场景
  • 010_第一代软件开发(二)
  • 基于若依ruoyi-nbcio增加flowable流程待办消息的提醒,并提供右上角的红字数字提醒(四)
  • RestTemplate:简化HTTP请求的强大工具
  • 【数据结构】什么是数据结构?
  • c++源码编译过程(翻译阶段)的若干细节概要
  • Go内置函数make和new的区别?
  • 动手学深度学习(pytorch版)第二章-2.3线性代数Note-linear-algebra
  • Docker CMD指令如何覆写
  • 动手吧,vue单独使用的复选框
  • 升级iOS17后可以降级吗?iOS17退回iOS16方法教程分享