成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python算法常用技巧與內置庫

開發 后端 算法
近些年隨著python的越來越火,python也漸漸成為了很多程序員的喜愛。許多程序員已經開始使用python作為第一語言來刷題。

 [[347377]]

python算法常用技巧與內置庫

近些年隨著python的越來越火,python也漸漸成為了很多程序員的喜愛。許多程序員已經開始使用python作為第一語言來刷題。

最近我在用python刷題的時候想去找點python的刷題常用庫api和刷題技巧來看看。類似于C++的STL庫文檔一樣,但是很可惜并沒有找到,于是決定結合自己的刷題經驗和上網搜索做一份文檔出來,供自己和大家觀看查閱。

1.輸入輸出:

1.1 第一行給定兩個值n,m,用空格分割,第一個n決定接下來有n行的輸入,m決定每一行有多少個數字,m個數字均用空格分隔.

解決辦法:python的input函數接收到的輸入默認都是字符串,所以我們使用 字符串切割、強制類型轉換、列表生成器就可以完美解決輸入問題。代碼如下: 

  1. # 接收兩個值,使用n,m分別接收列表中的兩個值  
  2. n, m  = [int(x) for x in input().split()]  
  3. # 構造輸入列表的列表  
  4. num_list = []  
  5. for i in range(n):  
  6.     # python可以不用在意m的值,將所有數值接收進來然后使用len判斷長度  
  7.     tmp_list = [int(x) for x in input().split()]  
  8.     num_list.append(tmp_list) 

同理,若是用逗號(,)分隔的話,split函數中傳入相同的值就行。

1.2 輸出一行數字

由于python的print函數默認利用換行作為結束符,所以我們需要將它修改成我們需要的間隔,代碼如下: 

  1. for i in range(10):  
  2.     print(i, end=' '

end是print函數中的一個參數,決定輸出的結束字符,這里修改成空格代表輸出一行數字,用空格間隔,其它字符可以自行修改。

2.空列表生成,字符串修改,列表遍歷

2.1 代碼編寫過程中,有時候會需要一個帶有長度的,有初始值的空列表,生成方式如下: 

  1. # 1. 用乘法生成一個初始值為False的長度為100的一維列表  
  2. visited = [False] * 100  
  3. # 2. 利用列表生成器生成一個n*m的二維的初始值為0的列表  
  4. visited = [[0 for i in range(m)] for j in range(n)] 

2.2 在python當中字符串是無法原地修改的,如果每次修改都生成一個新字符串,那么對修改次數很多且字符串很當的情況,開銷是很大的。所以一般是把字符串轉為列表進行修改最后再轉回來。 

  1. string = 'I love to eat chicken'  
  2. # 將字符串轉換成列表  
  3. string_list = list(string)  
  4. # .......對字符串列表進行修改  
  5. # Code  
  6. # 將字符串列表重新拼接成字符串  
  7. #string = ''.join(string_list) 

2.3 python中列表遍歷有許多種不同的方式,最直接的辦法是直接對列表進行迭代遍歷,但是因為我們往往是基于索引對數組進行操作且需要修改數組的值,所以更推薦用以下代碼中的第二三中辦法: 

  1. num_list = [i for i in range(10)]  
  2. # 1. 直接迭代列表  
  3. for item in num_list:  
  4.     # Code  
  5.     pass  
  6. # 2. 通過索引進行迭代  
  7. for i in range(len(num_list)):  
  8.     print(num_list[i])  
  9. # 3. 通過enumerate函數進行迭代  
  10. for index, value in enumerate(num_list):  
  11.     # index為當前元素的索引,value為當前元素的值  
  12.     print(index, value) 

3. collections庫的使用

3.1 deque隊列

deque 是python中的隊列(FIFO先進先出),隊列在進行隊首彈出的時候會比list要快。

尤其在使用BFS(深度優先搜索)的時候,隊列是必須要使用到的。部分deque使用代碼如下: 

  1. from collections import deque  
  2. # 初始化一個最大長度為3的隊列  
  3. d = deque([1,2,3], maxlen=3 
  4. # 因為初始化隊列最大長度為3,再添加元素會把隊頭元素擠出  
  5. d.append(4)  
  6. # 初始化一個不限制長度的隊列  
  7. d = deque()  
  8. # 添加元素到隊尾部  
  9. d.append(1)  
  10. d.append(2)  
  11. d.append(3)  
  12. # 將隊首的元素彈出返回  
  13. print(d.popleft())  
  14. # 彈出隊尾元素并返回值  
  15. print(d.pop())  
  16. # 在隊首插入元素  
  17. d.appendleft(0) 

3.2 Counter計數器

Counter 是一個計數器,可以對一個序列計數,計算序列中某個元素出現的數量。

以下是示例代碼: 

  1. import collections  
  2. # 一共有三種初始方法  
  3. # 1. 傳入一個序列  
  4. print(collections.Counter(['a', 'b', 'c', 'a', 'b', 'b']))  
  5. # 2.傳入一個字典 
  6. print(collections.Counter({'a':2, 'b':3, 'c':1}))  
  7. # 3.直接利用=傳參  
  8. print(collections.Counter(a=2b=3c=1))  
  9. # 也可以無參數構造,利用update函數更新  
  10. c = collections.Counter()  
  11. print('Initial :', c)  
  12. # Initial: Counter()  
  13. c.update('abcdaab')  
  14. print('Sequence:', c)  
  15. # Sequence: Counter({'a': 3, 'b': 2, 'c': 1, 'd': 1})  
  16. c.update({'a':1, 'd':5})  
  17. print('Dict:', c)  
  18. # Dict: Counter({'d': 6, 'a': 4, 'b': 2, 'c': 1})  
  19. # 可以通過訪問字典的訪問方式訪問Counter對象  
  20. for letter in 'abcde': 
  21.      print('%s : %d' % (letter, c[letter]))  
  22. # elements()方法可以返回一個包含所有Counter數據的迭代器  
  23. c = collections.Counter('extremely')  
  24. c['z'] = 0  
  25. print(list(c.elements()))  
  26. # ['e', 'e', 'e', 'm', 'l', 'r', 't', 'y', 'x']  
  27. # most_common()返回前n個最多的數據  
  28. c=collections.Counter('aassdddffff')  
  29. for letter, count in c.most_common(2):  
  30.     print('%s: %d' % (letter, count))  
  31. # f: 4  
  32. # d: 3  
  33. # Counter對象可以進行加減交并,直接使用運算符 +、-、&、|  
  34. # +會將兩個字典中相同字符的出現次數相加,-會給出第一個Counter相對于第二個的差集。交集給出兩個計數器當中都有的元素,且計數被賦值為較小的那個,并集為兩個計數器的元素出現最多的那個。  
  35. c1 = collections.Counter(['a', 'b', 'c', 'a', 'b', 'b'])  
  36. c2 = collections.Counter('alphabet')  
  37. print ('C1:', c1)  
  38. print ('C2:', c2)  
  39. print ('\nCombined counts:') 
  40. print (c1 + c2)  
  41. print ('\nSubtraction:')  
  42. print (c1 - c2)  
  43. print ('\nIntersection (taking positive minimums):')  
  44. print (c1 & c2) 
  45. print ('\nUnion (taking maximums):')  
  46. print (c1 | c2)  
  47. # 以下為輸出:  
  48. C1: Counter({'b': 3, 'a': 2, 'c': 1})  
  49. C2: Counter({'a': 2, 'l': 1, 'p': 1, 'h': 1, 'b': 1, 'e': 1, 't': 1})  
  50. Combined counts:  
  51. Counter({'a': 4, 'b': 4, 'c': 1, 'l': 1, 'p': 1, 'h': 1, 'e': 1, 't': 1})  
  52. Subtraction:  
  53. Counter({'b': 2, 'c': 1})  
  54. Intersection (taking positive minimums):  
  55. Counter({'a': 2, 'b': 1})  
  56. Union (taking maximums):  
  57. Counter({'b': 3, 'a': 2, 'c': 1, 'l': 1, 'p': 1, 'h': 1, 'e': 1, 't': 1}) 

3.3 defaultdict——帶有默認值的字典

一般情況下創建的字典dict是不含有默認值的,即若是字典中不包含a這個key,調用dct{a}的話就會報錯。

在進行算法設計和數據結構設計的時候我們希望任意給定一個key都能從字典中取出值來,哪怕只是一個默認值,這個時候我們就需要用到defaultdict。

例如在用字典表示圖中一個節點的相連節點的時候,我們希望將這個節點作為一個key,然后與它相連的節點組成一個列表作為它的value,這個時候我們就可以使用defaultdict(list)來創建一個默認值為列表的字典。 

  1. # list的默認值為空列表  
  2. list_dict = collections.defaultdict(list)  
  3. # int的默認值為0  
  4. int_dict = collections.defaultdict(int)  
  5. print(list_dict['a']) 
  6. print(int_dict['a'])  
  7. # 輸出:[]  
  8. # 輸出:0 

3.4 小結

collection中常被用來寫算法和數據結構的就是這幾個,其它比如排序字典和命名元組很少會用上。

4.排序

4.1 對列表排序

對列表排序有兩種方法,一種是使用列表內置的sort函數,sort函數直接在列表原地修改,無返回值,可以通過參數key自定義比較的key和比較函數。

第二種就是使用python的sorted函數,這個函數自由度比較高,可以自己設定比較函數和比較的key,返回一個新的列表。

如果需要自定義比較的函數,需要從庫functools導入函數cmp_to_key函數,將比較函數轉為key,使用代碼如下: 

  1. def custom_sort(x,y):  
  2.     if x>y:  
  3.         # 返回-1代表需要排在前面  
  4.         return -1  
  5.     if x<y:  
  6.         # 返回1代表需要排在后面  
  7.         return 1  
  8.     return 0  
  9. lst = [i for i in range(10, -1, -1)]  
  10. print(lst) 
  11. lst.sort()  
  12. print(lst)  
  13. print(sorted(lst, key=cmp_to_key(custom_sort)))  
  14. # 輸出如下:  
  15. # [10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0]  
  16. # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]  
  17. # [10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0] 

4.2 對字典/元組列表排序

若是需要對字典(將字典利用item函數轉化成元組列表)或者元組列表這種每一個item有兩個值的序列進行排序,這個時候就需要利用sorted函數中的key來決定取哪個值排序。代碼如下: 

  1. # 利用字符串創建計數器字典  
  2. d = dict(collections.Counter('Hello World'))  
  3. print(d)  
  4. # 排序  
  5. print(sorted(d.items(), key=lambda x: x[1], reverse=True))  
  6. # 輸出如下:  
  7. # {'H': 1, 'e': 1, 'l': 3, 'o': 2, ' ': 1, 'W': 1, 'r': 1, 'd': 1}  
  8. # [('l', 3), ('o', 2), ('H', 1), ('e', 1), (' ', 1), ('W', 1), ('r', 1), ('d', 1)] 

5.排列組合

python內置的模塊itertools中集成了一些與迭代有關的函數,其中就有排列組合函數。

5.1 排列

排列函數permutations接收一個列表,返回這個列表內所有元素的全排列列表。 

  1. from itertools import permutations  
  2. print(list(permutations([1,2,3])))  
  3. # 輸出如下:  
  4. # [(1, 2, 3), (1, 3, 2), (2, 1, 3), (2, 3, 1), (3, 1, 2), (3, 2, 1)] 

5.2 組合

組合函數combinations接收兩個參數,第一個為一個需要進行組合的列表,第二個參數為一個正整數,代表從列表中抽取多少個元素進行組合,返回一個組合列表。 

  1. from itertools import combinations  
  2. print(list(combinations([1,2,3],2)))  
  3. # 輸出如下:  
  4. # [(1, 2), (1, 3), (2, 3)] 

6.小技巧

6.1 在python中分了可變類型和不可變類型,當函數傳參的時候:

  •  若是不可變類型如字符串,則傳遞參數的時候會深拷貝一份,在新的數據上修改并不改變原數據
  •  若是可變類型如列表,則傳遞參數的時候傳遞的是引用,屬于淺拷貝,在函數中對新列表進行操作會影響到原來的列表。

若是確實需要傳遞可變類型進入函數,則可以在函數內部第一行進行一次深拷貝如: 

  1. def test(num_list:list):  
  2.     # 進行深拷貝  
  3.     num_listnum_list = num_list[:] 

6.2 當刪除列表中的元素的時候,列表后面的元素會自動往前移動,導致出錯

例如,列表為[1,2,3,4,5,6],想要刪除列表中的偶數,如果直接找到一個偶數然后利用其索引刪除,如下代碼所示(錯誤示范),那么很抱歉,出問題了。 

  1. # 此處為錯誤示范!?。。。。。。?nbsp; 
  2. lst = [1, 2, 3, 4, 5, 6]  
  3. for i in range(len(lst)):  
  4.     if lst[i] % 2 == 0:  
  5.         lst.pop(i)  
  6. print(lst)  
  7. # 上面這段代碼沒有輸出,因為報索引越界錯誤了。 

下面的代碼才是正確示范: 

  1. lst = [1, 2, 3, 4, 5, 6]  
  2. lst = [i for i in lst if i % 2 != 0]  
  3. print(lst)  
  4. # 輸出如下:  
  5. # [1, 3, 5] 

若是需要更復雜的篩選手段,可以在if i%2 !=0那里更改成一個函數判斷,函數內部就實現篩選方法。

6.3 訪問字典元素要使用get方法

前文說過,普通的dict字典是沒有默認值的,所以這個時候如果直接利用中括號放置key來查找value的話是有可能會報錯的。

那么為了避免這種情況,在利用字典的key來取value的時候,需要利用字典的get函數。

get函數的第一個參數為key,第二個參數為可選(默認為None),當字典中找不到傳入的key的時候,會返回第二個參數所賦的值。

7.小結

以上是本人在使用python刷題的時候作的一些總結,若有不到位的地方請指出。

本文旨在為自己做一個文檔,同時也為大家提供一些便利。

關注我的公眾號【程序小員】,收貨一大波福利知識。

我是落陽,謝謝你的到訪。 

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2021-07-26 08:31:10

CPP算法容器技巧

2016-10-20 20:21:09

Python爬蟲技巧

2011-09-02 10:06:51

OracleSqlLoad常用技巧

2016-10-21 14:35:52

Pythonwebget方法

2010-03-22 10:27:28

Python常用模塊I

2017-04-27 10:38:28

排序算法比較分析

2023-04-27 09:13:20

排序算法數據結構

2020-02-23 23:29:07

Python編程開發

2010-03-04 10:16:41

Python應用技巧

2021-03-16 10:12:24

python內置函數

2010-03-03 13:12:56

Python圖像處理

2020-07-31 08:07:54

Python開發數據庫

2020-06-04 10:49:53

Pandas字符串技巧

2011-07-01 16:05:22

SEO

2022-04-25 13:11:14

Python編程技巧

2023-11-24 11:11:08

Python數據庫

2024-01-24 13:14:00

Python內置函數工具

2011-02-25 15:31:19

MySQL數據庫DBA

2010-09-02 11:03:48

CSS

2025-06-06 10:00:00

內置模塊python開發
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日韩一区不卡 | 国产精品视频二区三区 | 久久久www成人免费无遮挡大片 | 日韩a在线 | www.久久国产精品 | 国产精品美女久久久久aⅴ国产馆 | 成人在线视频一区 | 草比网站| 成人免费在线小视频 | 国产一区二区影院 | 激情五月婷婷综合 | 久久久观看 | av中文字幕在线播放 | 玖玖精品视频 | 色播视频在线观看 | 亚洲国产精品久久久 | 99久久精品国产毛片 | hitomi一区二区三区精品 | 一区二区日韩精品 | 国产99久久精品一区二区永久免费 | 91最新在线视频 | 久久免费精品 | 粉嫩一区二区三区国产精品 | 免费久久99精品国产婷婷六月 | 亚洲一区视频在线播放 | 成在线人视频免费视频 | 91av在线看| 欧美一级欧美三级在线观看 | 国产一级片在线播放 | 欧美一区二区三区视频 | 亚洲精品永久免费 | 91看片在线观看 | 91视频在线 | 国产成人网 | 手机看片169 | 日韩精品一区二区三区中文在线 | 久久久久久一区 | 色视频欧美 | 欧美aaa| 免费在线观看一区二区 | 国产亚洲精品精品国产亚洲综合 |