遇到一个字符串翻转的问题,把可以用到的方法积累一下:
1.字符串切片:
result = s[::-1]
2.reverse( ):
l = list(s)
l.reverse()
result = "".join(l)
这里列表被改变了
3.reversed( ):
l=list(s)
result=list(reversed(l))
这里列表没有被改变
4.reduce( ):
result = reduce(lambda x,y:y+x,s)
注:
reduce函数 :
reduce() 函数会对参数序列中元素进行累积。函数将一个数据集合(链表,元组等)中的所有数据进行下列操作:用传给 reduce 中的函数 function(有两个参数)先对集合中的第 1、2 个元素进行操作,得到的结果再与第三个数据用 function 函数运算,最后得到一个结果。
reduce()的函数原型是: reduce(function(), iterable, initializer),返回值是一个单值
lambda函数 :
lambda表达式,通常是在需要一个函数,但是又不想费神去命名一个函数的场合下使用,也就是指匿名函数。
表达式 = lambda [parameters,即参数] : [func,即执行的运算过程]
5.栈:
def func(s):
l = list(s) #模拟全部入栈
result = ""
while len(l)>0:
result += l.pop() #模拟出栈
return result
result = func(s)
注:
栈的定义:栈是限定仅在表头进行插入和删除操作的线性表。要搞清楚这个概念,首先要明白”栈“原来的意思,如此才能把握本质。"栈“者,存储货物或供旅客住宿的地方,可引申为仓库、中转站,所以引入到计算机领域里,就是指数据暂时存储的地方,所以才有进栈、出栈的说法,其插入和删除操作都在栈顶进行操作,并且按照先进后出,后进先出的规则进行运作。在python中用列表来模拟栈,python中用append()模拟进栈,pop( )模拟出栈。队列先进先出。栈就是一个桶,后放进去的先拿出来,它下面本来有的东西要等它出来之后才能出来。(后进先出)队列只能在队头做删除操作,在队尾做插入操作.而栈只能在栈顶做插入和删除操作。(先进先出)
6.递归函数:
def func(s):
if len(s) <1:
return s
return func(s[1:])+s[0]
result = func(s)
7.for循环:
def func(s):
result = ""
max_index = len(s)-1
for index,value in enumerate(s):
result += s[max_index-index]
return result
result = func(s)
注:
python enumerate 用法 : 在for循环中得到计数
参数为可遍历的变量,如 字符串,列表等;
返回值为enumerate类:
在同时需要index和value值的时候可以使用 enumerate。
这里只是为了得到index.