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

LeeCode题库第五十题

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


问题描述

        这里借用灵神的图灵神题解,每个幂相当于不断相乘一、二、四、八次方,但不是每一个都要去乘,可以联想二进制8421,此时二进制位为1时说明要成此时x的幂,之后x每轮翻倍,循环结束后返回即可。

lc50-3-c.png

class Solution:
    def myPow(self, x: float, n: int) -> float:
        ans=1
        if n<0:
            n=-n
            x=1/x
        while n:
            if n&1:
                ans*=x
            x*=x
            n>>=1
        return ans

       
        

        本题提交情况。 

 

        以上为本篇文章的全部内容,感谢你抽出宝贵的时间阅读这篇文章。如果你有任何疑问或建议,欢迎在评论区留言,我们一起交流进步。愿你的代码之路越走越顺,生活充满阳光!   

 

 


http://www.kler.cn/a/581084.html

相关文章:

  • mac安装java环境
  • 【面试】计算机网络
  • 在Visual Studio 2022中实现Qt插件开发
  • 蓝桥杯嵌入式组第七届省赛题目解析+STM32G431RBT6实现源码
  • Python从入门到精通1:FastAPI
  • 现代优雅品牌杂志广告邀请函设计衬线手写英文字体 Buttercy Font Duo
  • 深入解析 C 语言中含数组和指针的构造体与共同体内存计算
  • 【数据结构】二叉搜索树、平衡搜索树、红黑树
  • HTML <head> 元素详解:网页头部的关键组成部分
  • ragflow-组件可视化工具 es默认用户名elastic
  • sonarqube+SonarScanner+postpresql+jenkins
  • 解决 React 中的 Hydration Failed 错误
  • 打造智能钉钉机器人:借助智谱GLM-4-Flash实现高效智能回复(文末附源码)
  • leetcode1143.最长公共子序列
  • 【设计模式】掌握建造者模式:如何优雅地解决复杂对象创建难题?
  • 用Qt手搓AI助手,挑战24小时开发DeepSeek Assistant!
  • 分布式系统中分布式ID生成方案的技术详解
  • 如何在c# 项目中使用redis
  • 跟踪napi_gro_receive_entry时IP头信息缺失的分析
  • Spring有哪些缺点?