题目四 实现字符串反转
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 '''