題目四 實現字符串反轉
1 #方式一 循環 2 temStr='adbeorj1305' 3 newStr='' 4 i=0 5 while i< len(temStr): 6 newStr=newStr+temStr[len(temStr)-1-i] 7 i=i+1 8 print(newStr,'字符串反轉') 9 10 #方式二 切片 11 temStr='adbeorj1305' 12 print(temStr[::-1],'切片') 13 14 #方式三 使用列表的reverse方法 15 temStr='adbeorj1305' 16 L1=list(temStr) 17 L1.reverse() 18 S2=''.join(L1) 19 print(S2,'借用列表的反轉方法')
1 #方式四 使用reduce lambda 2 #lambda用來編寫簡單的函數,而def用來處理更強大的任務。哪一種方式更清晰就用哪種方式,不要盲目的都使用lambda表達式。
3 4 #方式五 使用棧 5 temStr='adbeorj1305' 6 L1=list(temStr) 7 S1='' 8 while len(L1)>0: 9 S1=S1+L1.pop() 10 print(S1,'使用棧,採用pop方式') 11 #######################下面是failure的例子 12 temStr='adbeorj1305' 13 L1=list(temStr) 14 S1='' 15 for i in L1: 16 S1=S1+L1.pop() #也是依次pop後,拼接 17 print(S1,'L1',L1) 18 # print(S1,'使用棧,採用pop方式',L1) 19 # #輸出結果是:5031jr 爲啥後面的沒有執行,(⊙o⊙)…, 20 ''' 21 分析緣由:pop執行後,L1的長度在變,而i in L1中i訪問的索引值在不斷增大, 22 當i=r,進入下一次循環時index=6, 23 但此時L1=['a', 'd', 'b', 'e', 'o']最大index=5, 24 所以循環結束,後續元素沒法追加。 25 '''