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 '''