剑指 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

浙公网安备 33010602011771号