超级素数幂 Python 版
来源:互联网 发布:js实现继承的方法 编辑:程序博客网 时间:2024/05/16 10:55
- 题目:
- 如果一个数字能表示成 p^q,且p是一个素数,q为大于1的正整数,则此数字就是超级素数幂。
param number: 测试该数字是否是超级素数幂
return: 如果不是就返回 False,如果是就返回 p 和 q 值
例如,输入125,返回(5,3)
代码:
import mathdef get_prime(number): ''' 寻找小于number的所有的质数,时间复杂度o(n^2) ''' if number <= 1: print 'Wrong given number.' return prime = [] for i in xrange(2, number+1): j = 2 while j < i: if i % j == 0: break j += 1 if j == i: prime.append(i) return primedef super_prime_power(number): scope = int(math.ceil(math.sqrt(number))) # 开根号除掉一部分不需要的数 prime_number = get_prime(scope) be_tested = [] for i in prime_number: # 先将无法被整数的排除掉 if number % i == 0: be_tested.append(i) for p in be_tested: q = 2 while p ** q <= number: if p ** q == number: return (p, q) q += 1 return Falseprint super_prime_power(999)
分析:
总的时间复杂度为o(sqrt(n)log n),再加上寻找质数花费的时间,总的时间复杂度为o(n^2 sqrt(n)log n)
阅读全文
0 0
- 超级素数幂 Python 版
- 超级素数幂
- 超级素数幂
- 超级素数幂
- 超级素数幂
- 超级素数幂
- 超级素数幂解题报告
- [编程题]超级素数幂
- 超级素数
- 超级素数
- 超级素数
- 超级素数
- 牛客模拟一:超级素数幂
- [usaco]超级素数 superprime
- 神秘的超级素数
- 超级素数实现算法
- P2667 超级素数
- 【牛客网 2017年校招模拟笔试(第一场)】超级素数幂
- Cannot complete the install because one or more required items could not be found解决办法
- MySQL常用SQL语句
- STM32高级定时器(1)
- (C#)Windows Shell 外壳编程系列8
- 数据结构实验之图论六:村村通公路
- 超级素数幂 Python 版
- Android跳转到手机系统各个设置界面的方法及其列表
- 写一个字符串反转函数,输入 abcdef 转换成 edcba
- 删除文件夹、脚本运行cmd命令、解压缩zip
- 面向对象继承关系基本架构
- mysql 取得爬取数据数并插入服务器
- ExecutorService 的理解与使用
- AES 后台加密 CryptoJS 前台解密demo
- mysql--索引功能