国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

python判斷數字是否是超級素數冪

2020-02-15 23:03:48
字體:
來源:轉載
供稿:網友

如果一個數字能表示成 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)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宜春市| 萝北县| 广安市| 大港区| 四平市| 连江县| 双流县| 剑川县| 临西县| 进贤县| 武城县| 繁昌县| 福建省| 威海市| 伊川县| 宜兰县| 玉田县| 西城区| 大邑县| 旬邑县| 丰县| 东乡| 兴国县| 襄垣县| 石楼县| 灵寿县| 南木林县| 莱阳市| 英德市| 东阳市| 江源县| 陆河县| 南汇区| 嘉义市| 鲁甸县| 田阳县| 牟定县| 车险| 安龙县| 广南县| 上林县|