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

首頁 > 編程 > Python > 正文

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

2020-01-04 14:26:58
字體:
來源:轉載
供稿:網友

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

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


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 全州县| 类乌齐县| 福海县| 深州市| 勐海县| 霍山县| 昌宁县| 永昌县| 阿拉善右旗| 鄯善县| 嘉荫县| 甘德县| 苏州市| 曲阜市| 玛沁县| 乡宁县| 罗江县| 哈密市| 若羌县| 遵化市| 宣化县| 郸城县| 龙口市| 哈巴河县| 息烽县| 甘孜| 丽江市| 共和县| 达州市| 襄汾县| 墨江| 彝良县| 丰顺县| 巨野县| 望都县| 罗山县| 化州市| 陇川县| 张掖市| 互助| 迁西县|