方式一 循环
temStr='adbeorj1305' newStr='' i=0 while i< len(temStr): newStr=newStr+temStr[len(temStr)-1-i] i=i+1 print(newStr,'字符串反转')
方式二 切片
temStr='adbeorj1305' print(temStr[::-1],'切片')
方式三 使用列表的reverse方法
''' 遇到问题没人解答?小编创建了一个Python学习交流: 寻找有志同道合的小伙伴,互帮互助,群里还有不错的视频学习教程和PDF电子书! ''' temStr='adbeorj1305' L1=list(temStr) L1.reverse() S2=''.join(L1) print(S2,'借用列表的反转方法')
方式四 使用reduce lambda
lambda用来编写简单的函数,而def用来处理更强大的任务。哪种方式更清晰就用哪一种方式,不要盲目的都使用lambda表达式。
方式五 使用栈
temStr='adbeorj1305' L1=list(temStr) S1='' while len(L1)>0: S1=S1+L1.pop() print(S1,'使用栈,采用pop方式') 下面是failure的例子 temStr='adbeorj1305' L1=list(temStr) S1='' for i in L1: S1=S1+L1.pop() #也是依次pop后,拼接 print(S1,'L1',L1) # print(S1,'使用栈,采用pop方式',L1) # #输出结果是:5031jr 为啥后面的没有执行,(⊙o⊙)…, ''' 分析原因:pop执行后,L1的长度在变,而i in L1中i访问的索引值在不断增大, 当i=r,进入下一次循环时index=6, 但此时L1=['a', 'd', 'b', 'e', 'o']最大index=5, 因此循环结束,后续元素无法追加。 '''
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/228574.html原文链接:https://javaforall.net
