Python丑数

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

空间换时间。建立一个长度为n的数组,保存这n个丑数。在进行运算的时候,某个位置需要求得丑数一定是前面某个丑数乘以2、3或者5的结果,我们分别记录之前乘以2后能得到的最大丑数M2,乘以3后能得到的最大丑数M3,乘以5后能得到的最大丑数M5,那么下一个丑数一定是M2,M3,M5中的最小的那一个。同时注意到,已有的丑数是按顺序存放在数组中的。对乘以2而言,肯定存在某一个丑数T2,排在他之前的每一个丑数乘以2得到的结果都会小于已有的最大丑数,在他之后的每一个丑数乘以2得到的结果都会太大,我们只需记下这个丑数的位置,每次生成新的丑数的时候,去更新这个T2。对于3和5同理。

  1. '''
  2. 把只包含因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含因子7。
  3. 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。
  4. '''
  5. # -*- coding:utf-8 -*-
  6. class Solution:
  7. def GetUglyNumber_Solution(self, index):
  8. if index == None and len(index) <= 0:
  9. return 0
  10. uglyNumbers = [1]*index
  11. nextIndex = 1
  12. index2 = 0
  13. index3 = 0
  14. index5 = 0
  15. while nextIndex < index:
  16. minVal = min(uglyNumbers[index2]*2, uglyNumbers[index3]*3, uglyNumbers[index5]*5)
  17. uglyNumbers[nextIndex] = minVal
  18. while uglyNumbers[index2]*2 <= uglyNumbers[nextIndex]:
  19. index2 += 1
  20. while uglyNumbers[index3]*3 <= uglyNumbers[nextIndex]:
  21. index3 += 1
  22. while uglyNumbers[index5]*5 <= uglyNumbers[nextIndex]:
  23. index5 += 1
  24. nextIndex += 1
  25. return uglyNumbers[-1]
  26. s = Solution()
  27. print(s.GetUglyNumber_Solution(11))
  28. # def getUglyNumber(index):
  29. # if index <= 0:
  30. # return 0
  31. #
  32. # uglyNumbers = [1] * index
  33. # nextUglyIndex = 1
  34. #
  35. # index2 = 0
  36. # index3 = 0
  37. # index5 = 0
  38. # multiply2 = uglyNumbers[index2]
  39. # multiply3 = uglyNumbers[index3]
  40. # multiply5 = uglyNumbers[index5]
  41. #
  42. # while nextUglyIndex < index:
  43. # minVal = min(multiply2 * 2, multiply3 * 3, multiply5 * 5)
  44. # uglyNumbers[nextUglyIndex] = minVal
  45. #
  46. # while multiply2 * 2 <= uglyNumbers[nextUglyIndex]:
  47. # index2 += 1
  48. # multiply2 = uglyNumbers[index2]
  49. # while multiply3 * 3 <= uglyNumbers[nextUglyIndex]:
  50. # index3 += 1
  51. # multiply3 = uglyNumbers[index3]
  52. # while multiply5 * 5 <= uglyNumbers[nextUglyIndex]:
  53. # index5 += 1
  54. # multiply5 = uglyNumbers[index5]
  55. #
  56. # nextUglyIndex += 1
  57. # return uglyNumbers[-1]
解压密码: detechn或detechn.com

免责声明

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

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

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

Python把数组排成最小数
« 上一篇 01-21
Python第一个只出现一次的字符
下一篇 » 01-21

发表评论