zoukankan      html  css  js  c++  java
  • 【python练习题】实现字符串反转

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


  • 相关阅读:
    无锁编程(五)
    Linux Kernel CMPXCHG函数分析
    无锁编程(四)
    无锁编程(三)
    无锁编程(二)
    无锁编程(一)
    无锁编程
    Linux同步机制
    Linux同步机制
    bootstrap css编码规范
  • 原文地址:https://www.cnblogs.com/ww-xiaowei/p/11310705.html
Copyright © 2011-2022 走看看