某企业招聘题目:获取最小的10000个素因子只有2、3、5的数

jthmath · · 3698 次点击
我们不要用对数字进行检验的方法,不管检验的速度快慢,都需要检验太多数字了。 根据我计算的结果,第10000个数字是:288555831593533440。 你们说如果检验数字,要检验多久吧。即使采用各种方法排除了一大批数字,并且单个数字的检验很快,这个数量级也太大了。 所以采用生成数字的方法。 我们只要保证有一个数据仓库,这个仓库可以很方便的按从小到大的顺序取出值,同时插入新的值时,能够保持有序(最好插入时维护有序的操作时间尽可能短)即可。
#22
更多评论
```python #! /usr/bin/env python def mul_nums(nums,size): curnums = [] retnums = [] minnum = nums[0] for c in nums: curnums.append(c) retnums.append(c) if c < minnum: minnum = c i = len(retnums) while i < size: minnum = curnums[0] minidx = 0 idx = 0 for c in curnums: if c < minnum: minnum = c minidx = idx idx += 1 minmulnum = curnums[0] * nums[0] for c in curnums: for d in nums: if (c * d) < minmulnum: minmulnum = (c * d) retnums.append(curnums[minidx]) curnums[minidx] = minmulnum i += 1 return retnums def main(): retnums = mul_nums([2,3,5],10000) for c in retnums: print('[%d]\n'%(c)) main() ```
#1
``` #!/usr/bin/env python # -*- coding:utf-8 -*- """ 10000以内 素因子只有2,3,5的数 只需要log2(10000) * log3(10000)*log5(10000)次循环 520次 最终的数据个数小于这个数 """ import math def findOnly235(): max = 10000 maxL2 = int(math.log(max, 2)) maxL3 = int(math.log(max, 3)) maxL5 = int(math.log(max, 5)) print maxL2, maxL3, maxL5 L = [] for i in range(maxL2): for j in range(maxL3): for k in range(maxL5): number = pow(2, i) * pow(3, j) * pow(5, k) if number <= max and number > 1: L.append(number) return L if __name__ == '__main__': l = findOnly235() l.sort() print l ```
#2