今天練習了一下用python寫函數,就把它記錄到部落格上吧 冒泡排序和素數判斷

來源:互聯網
上載者:User

標籤:

第一個是判斷素數,先上代碼吧:

 1 from math import sqrt 2 def is_prime(i): 3     if i == 2: 4         return  True 5     elif i<2: 6         return False 7     elif i%2 == 0: 8         return False 9     else:10         for n in range(3,int(sqrt(i)+1),2):11             if i%n == 0:12                 return False13     return True

這裡用到了math包的sqrt,為了儘可能提高效率,少迴圈幾次,這裡有個range函數,有三個參數,分別是起點,終點,間隔,間隔是可選的,像range(0,12,3就是[0,3,6,9]。

 

第二個是冒泡排序,還是上代碼:

import randomlist = range(0,10)for i in list:    print (i)random.shuffle(list)for i in list:    print (i)for d in range(len(list)-1,0,-1):    for e in range(0,d,1):        if list[e] > list[e+1]:            list[e],list[e+1] = list[e+1],list[e]for i in list:    print (i)

  這個很有意思了,包含了一個random包,因為我想把有序的數組打亂,用了這個random.shuffle函數,冒泡排序沒什麼好說的,唯一需要注意的是這句

list[e],list[e+1] = list[e+1],list[e],是不是很爽,都不用第三方變數,不過好像編譯的時候還是會產生第三方變數。這裡再給自己留一個問題,自己實現random.shuffle()。
昨天問題的代碼:
def volid(pwd):     a = any(map(str.isupper,pwd))     b = any(map(str.islower,pwd))     c = any(map(str.isdigit,pwd))     d = not all(map(str.isalnum,pwd))     if sum([a,b,c,d])>1:        return True     else:         return False

  

今天練習了一下用python寫函數,就把它記錄到部落格上吧 冒泡排序和素數判斷

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.