今天給大家分享30道Python練習題,建議大家先獨立思考一下解題思路,再查看答案。
1. 已知一個字符串為 “hello_world_yoyo”,如何得到一個隊列 [“hello”,”world”,”yoyo”] ?
使用 split 函數(shù),分割字符串,并且將數(shù)據(jù)轉(zhuǎn)換成列表類型:
結(jié)果:
['hello', 'world', 'yoyo']
2. 有個列表 [“hello”, “world”, “yoyo”],如何把列表里面的字符串聯(lián)起來,得到字符串 “hello_world_yoyo”?
使用 join 函數(shù)將數(shù)據(jù)轉(zhuǎn)換成字符串:
結(jié)果:
如果不依賴 python 提供的 join 方法,還可以通過 for 循環(huán),然后將字符串拼接,但是在用“+”連接字符串時,結(jié)果會生成新的對象,使用 join 時結(jié)果只是將原列表中的元素拼接起來,所以 join 效率比較高。
for 循環(huán)拼接如下:
3. 把字符串 s 中的每個空格替換成”%20”,輸入:s = “We are happy.”,輸出:“We%20are%20happy.”。
使用 replace 函數(shù),替換字符換即可:
結(jié)果:
4. Python 如何打印 99 乘法表?
for 循環(huán)打印:
while 循環(huán)實現(xiàn):
i = 1
while i <= 9:
j = 1
while j <= i:
print("%d*%d=%-2d"%(i,j,i*j),end = ' ') # %d: 整數(shù)的占位符,'-2'代表靠左對齊,兩個占位符
j += 1
print()
i += 1
結(jié)果:
5. 從下標 0 開始索引,找出單詞 “welcome” 在字符串“Hello, welcome to my world.” 中出現(xiàn)的位置,找不到返回 -1。
6. 統(tǒng)計字符串“Hello, welcome to my world.” 中字母 w 出現(xiàn)的次數(shù)。
7. 輸入一個字符串 str,輸出第 m 個只出現(xiàn)過 n 次的字符,如在字符串 gbgkkdehh 中,找出第 2 個只出現(xiàn) 1 次的字符,輸出結(jié)果:d
8. 判斷字符串 a = “welcome to my world” 是否包含單詞 b = “world”,包含返回 True,不包含返回 False。
9. 從 0 開始計數(shù),輸出指定字符串 A = “hello” 在字符串 B = “hi how are you hello world, hello yoyo!”中第一次出現(xiàn)的位置,如果 B 中不包含 A,則輸出 -1。
10. 從 0 開始計數(shù),輸出指定字符串 A = “hello”在字符串 B = “hi how are you hello world, hello yoyo!”中最后出現(xiàn)的位置,如果 B 中不包含 A,則輸出 -1。
11. 給定一個數(shù) a,判斷一個數(shù)字是否為奇數(shù)或偶數(shù)。
12. 輸入一個姓名,判斷是否姓王。
13. 如何判斷一個字符串是不是純數(shù)字組成?
利用 Python 提供的類型轉(zhuǎn)行,將用戶輸入的數(shù)據(jù)轉(zhuǎn)換成浮點數(shù)類型,如果轉(zhuǎn)換拋異常,則判斷數(shù)字不是純數(shù)字組成。
14. 將字符串 a = “This is string example….wow!” 全部轉(zhuǎn)成大寫,字符串 b = “Welcome To My World” 全部轉(zhuǎn)成小寫。
15. 將字符串 a = “ welcome to my world ”首尾空格去掉
Python 提供了strip() 方法,可以去除首尾空格,rstrip() 去掉尾部空格,lstrip() 去掉首部空格,replace(" ", “”) 去掉全部空格。
還可以通過遞歸的方式實現(xiàn):
通過 while 循環(huán)實現(xiàn):
16. 將字符串 s = “ajldjlajfdljfddd”,去重并從小到大排序輸出”adfjl”。
17. 打印出如下圖案(菱形):
18. 給一個不多于 5 位的正整數(shù)(如 a = 12346),求它是幾位數(shù)和逆序打印出各位數(shù)字。
19. 如果一個 3 位數(shù)等于其各位數(shù)字的立方和,則稱這個數(shù)為水仙花數(shù)。例如:153 = 13 + 53 + 33,因此 153 就是一個水仙花數(shù)。那么如何求 1000 以內(nèi)的水仙花數(shù)(3 位數(shù))。
20. 求 1+2+3…+100 相加的和。
21. 計算 1-2+3-4+5-…-100 的值。
22. 現(xiàn)有計算公式 13 + 23 + 33 + 43 + …….+ n3,如何實現(xiàn):當輸入 n = 5 時,輸出 225(對應(yīng)的公式 : 13 + 23 + 33 + 43 + 53 = 225)。
23. 已知 a 的值為“hello”,b 的值為“world”,如何交換 a 和 b 的值,得到 a 的值為“world”,b 的值為”hello”?
24. 如何判斷一個數(shù)組是對稱數(shù)組?
例如 [1,2,0,2,1],[1,2,3,3,2,1],這樣的數(shù)組都是對稱數(shù)組。用 Python 判斷,是對稱數(shù)組打印 True,不是打印 False。
25. 如果有一個列表 a = [1,3,5,7,11],那么如何讓它反轉(zhuǎn)成 [11,7,5,3,1],并且取到奇數(shù)位值的數(shù)字 [1,5,11]?
26. 對列表 a = [1, 6, 8, 11, 9, 1, 8, 6, 8, 7, 8] 中的數(shù)字從小到大排序。
27. 找出列表 L1 = [1, 2, 3, 11, 2, 5, 3, 2, 5, 33, 88] 中最大值和最小值。
上面是通過 Python 自帶的函數(shù)實現(xiàn),如下,可以自己寫一個計算程序:
28. 找出列表 a = [“hello”, “world”, “yoyo”, “congratulations”] 中單詞最長的一個。
29. 取出列表 L1 = [1, 2, 3, 11, 2, 5, 3, 2, 5, 33, 88] 中最大的三個值。
30. 把列表 a = [1, -6, 2, -5, 9, 4, 20, -3] 中的數(shù)字絕對值。