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

题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. ",则输出"student. a am I"。  简单
方法:双指针倒叙  时间复杂度O(n)  空间复杂度O(n) 

def reverseWords(s):
        """
        :type s: str
        :rtype: str
        """
        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])  # j越界也无所谓
            while i >= 0 and s[i] == ' ':
                i -= 1
            j = i
        return ' '.join(res)  # join 在序列之间添加''生成字符串  如'-' a-b-c

 

posted @ 2022-07-27 20:32  Liang-ml  阅读(20)  评论(0)    收藏  举报