剑指 Offer 58 - I. 翻转单词顺序python

题目描述:

题解一:

python库split自动去掉字符串首位和中间多余的空格

class Solution(object):
    def reverseWords(self, s):
        words = s.split()
        words.reverse()
        result = " "
        return result.join(words)

 题解二:双指针

参考剑指 Offer 58 - I. 翻转单词顺序(双指针/python库函数) - Yelush - 博客园

1.首先去除s前后的空格,i j记录单词的左右边界,初始化i,j=len(s)-1

class Solution(object):
    def reverseWords(self, s):
        s = s.strip()
        i = j = len(s)-1
        res = []
        while i>=0:
            while i>=0 and s[i]!=' ':
                i-=1
            res.append(s[i+1:j+1])
            while s[i]==' ':
                i = i-1
            j = i
        return " ".join(res)

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值