国产探花免费观看_亚洲丰满少妇自慰呻吟_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)

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 犍为县| 乌拉特后旗| 八宿县| 镇赉县| 文成县| 西华县| 江津市| 长乐市| 旌德县| 郧西县| 巴青县| 手机| 六枝特区| 五家渠市| 镶黄旗| 永修县| 平泉县| 顺平县| 象州县| 茂名市| 车致| 曲阜市| 平阴县| 体育| 平陆县| 田林县| 乌审旗| 宜黄县| 宁津县| 磴口县| 班玛县| 延长县| 枣阳市| 东辽县| 凉城县| 福建省| 临湘市| 且末县| 东丽区| 祥云县| 天水市|