記錄一些基礎編程練習題和一些遇見的坑
1)輸出0到100的數字,如果數字是3的倍數輸出Fizz,5的倍數輸出Buzz。同時是3和5的倍數輸出FizzBuzz,其他情況則打印原數字
for i in range(100): if i==0: print(i) elif i%3==0 and i%5==0: print("FizzBuzz") elif i%3==0: print("Fizz") elif i%5==0: print("Buzz") else: print(i)
ps:條件語句依次執行,滿足第一個條件后不會執行下一個條件。所以同時滿足3和5的需要放在上面。
2)根據輸入的數字,打印相對應層數的等腰三角形星星塔
ps:先打印空格,空格數量:總層數-當前層數。再打印星星,星星數量:當前層數*2-1
如range(1,7),生成的數列是1到6,所以需要通過num+1的方式來控制層數
print()里end=""可以讓打印時不換行
2*i是星星的數量,利用range()自動減一。-、
使用while循環實現
row為層數,默認為第一層
num-row為空格數量
2*row-1位星星數量
3)有1,2,3,4四個數字,能組成多少個互不相同且不重復的三位數字
三個數字可填在個十百位上,組成所有排列然后去掉重復的
4)遞歸返回None值
在做下面一題的時候,我如果直接輸1到4是沒有問題的,但是如果輸入不是數字,或者不是1到4的數字,會返回None值
后來查了很多才發現。這樣寫遞歸調用后產生的值並沒有return出來,要在遞歸函數調用前加上return。把值一層層傳出去。
5)編寫一個程序,提示“選擇運算符”,輸入“1/2/3/4”后,繼續輸入要進行運算的兩個數字后,打印出運算結果
ps:這個做了很久,一個是遞歸返回值的問題。還有一個通過字典存放函數指針。減少代碼量
前四個是加減乘除的函數,然后存放到字段里,然后字典名[key](函數的參數)這樣的形式調用。就不用寫很多判斷的代碼。
6)冒泡排序,數組之間相鄰值,兩兩進行比較。然后從大到小,或者從小到大排序
數組的下標是從0開始的
從大到小排是找出最小的放到最后面,從小到大排是找出最大的放到最后面
ps:以上圖從大到小排序為例。第一輪是7個數進行比較,然后比較出最小的值放在最后。然后第二輪比較前6個值。以此類推。剩下2個數的時候,一次比完。所以需要比的輪次是 數組的長度減去1 。每輪需要比較數量,第一輪是數組長度,之后每輪減1.
7)二分查詢,對一個有序的數組進行查詢,從數組中間取出一個值,和需要查詢的值進行對比。如果大於需要查詢的值,則取左邊一半繼續進行二分查詢。如果小於需要查詢的值,則取右邊一半繼續進行二分查詢。如果相同,則給出下標。沒有提示沒找到
使用循環實現
left和right確定數組下標區間,找到中間值,比較大小后,根據升序還是降序的排序方式。來確定更換左邊還是右邊的下標。
一定要<= 因為數組最小或最大時,left=right
left一定要+1,不然會導致查詢數組最大時,取中間值下標這步出現死循環
使用遞歸實現
ls = [10,20,30] def binary_search(alist,item,left,right): if left > right: return None numb = int((left+right)/2) if alist[numb] == item: return numb elif item > alist[numb]: return binary_search(alist,item,numb+1,right) else: return binary_search(alist,item,left,numb-1) s = binary_search(ls,10,0,3) print(s)