日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

Python實現高效求解素數代碼實例

系統 1781 0

素數是編程中經常需要用到的。

作為學習Python的示例,下面是一個高效求解一個范圍內的素數的程序,不需要使用除法或者求模運算。

            
#coding:utf-8    #設置python文件的編碼為utf-8,這樣就可以寫入中文注釋
def primeRange(n):
  myArray=[1 for x in range(n+1)] ##列表解析,生成長度為(n+1)的列表,每個數值都為1
  myArray[0]=0
  myArray[1]=0
  startPos=2
  while startPos <= n:
    if myArray[startPos]==1:
      key=2
      resultPos = startPos * key #可知startPos的整數倍都不是素數,設置startPos的整數倍的位置為0表示非素數
      while resultPos <= n:
        myArray[resultPos] =0
        key += 1
        resultPos = startPos *key
    startPos += 1

  resultList=[]  ##將最終的素數保存在resultList列表返回
  startPos=0
  while startPos <= n:
    if myArray[startPos] == 1:
      resultList.append(startPos)
    startPos += 1
  return resultList

numString=raw_input("Input the Range(>3):")
numInt=int(numString)
if numInt <= 3:
  print "The Number Need to be greater than 3"
else:
  primeResult=primeRange(numInt)
  print "The Result is:",primeResult

          

更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 屏边| 兴安县| 疏附县| 夏河县| 于田县| 太原市| 新竹县| 兴仁县| 惠州市| 香河县| 荃湾区| 昭觉县| 沁源县| 个旧市| 沭阳县| 邵东县| 大埔县| 文山县| 东城区| 虞城县| 南充市| 河间市| 邵阳市| 谷城县| 临潭县| 肃宁县| 彰化县| 青龙| 龙陵县| 桑日县| 巴中市| 宣威市| 巴塘县| 郸城县| 盖州市| 泾阳县| 上饶县| 星座| 思茅市| 白城市| 苗栗市|