Python数值的整数次方

本文阅读 2 分钟
首页 Python笔记 正文

如果采用常规解法,需要注意的地方:当指数为负数的时候;当底数为零且指数为负数的情况;在判断底数base是不是等于0的时候,不能直接写base==0, 因为计算机内表示小数时有误差,只能判断他们的差的绝对值是不是在一个很小的范围内。如果采用递归解法,当n为偶数, an = an/2 an/2,当n为奇数, an = a(n-1)/2 a(n-1)/2 * a,利用右移一位代替除2运算,利用 &1 判断是否为奇数。同时需要注意递归终止条件,exponent = 1的话,return base,exponent = -1的话,return 1.0/base。再次提醒!必须写成 1.0/base,否则 1/base,返回一个integer 0!

  1. '''
  2. 给定一个double类型的浮点数base和int类型的整数exponent。求base的exponent次方。
  3. '''
  4. '''
  5. 需要注意的地方:
  6. 当指数为负数的时候
  7. 当底数为零切指数为负数的情况
  8. 在判断底数base是不是等于0的时候,不能直接写base==0, 因为计算机内表示小数时有误差,只能判断他们的差的绝对值是不是在一个很小的范围内
  9. '''
  10. '''
  11. 当n为偶数, a^n = a^(n/2) * a^(n/2)
  12. 当n为奇数, a^n = a^((n-1)/2) * a^((n-1)/2)) * a
  13. 利用右移一位运算代替除以2
  14. 利用位与运算代替了求余运算法%来判断一个数是奇数还是偶数
  15. 优化代码速度
  16. '''
  17. class Solution:
  18. def Power(self, base, exponent):
  19. if exponent == 0:
  20. return 1
  21. if exponent == 1:
  22. return base
  23. if exponent == -1:
  24. return 1/base
  25. result = self.Power(base, exponent >> 1)
  26. result *= result
  27. if (exponent & 0x1) == 1:
  28. result *= base
  29. return result
  30. S = Solution()
  31. print(S.Power(5, -10))
解压密码: detechn或detechn.com

免责声明

本站所有资源出自互联网收集整理,本站不参与制作,如果侵犯了您的合法权益,请联系本站我们会及时删除。

本站发布资源来源于互联网,可能存在水印或者引流等信息,请用户自行鉴别,做一个有主见和判断力的用户。

本站资源仅供研究、学习交流之用,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担。

Python二进制中1的个数
« 上一篇 01-21
Python打印1到最大的n位数
下一篇 » 01-21

发表评论

惪特博客
  • 文章总数:
    18474 篇
  • 评论总数:
    53223 条
  • 标签总数:
    8841 个
  • 总浏览量:
    21072798 次
  • 最后更新:
    2024年12月07日

最多点赞

随便看看

标签TAG