python技巧3:字符串翻转方法

遇到一个字符串翻转的问题,把可以用到的方法积累一下:

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.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值