【剑指Offer】翻转单词顺序列 解题报告(Python)

标签(空格分隔): 剑指Offer


题目地址:https://www.nowcoder.com/ta/coding-interviews

题目描述:

牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a student.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?

解题方法

当然可以用[::-1]搞定呀,但是题目肯定不是这个意思。

正确的做法是,县翻转整个字符串, 然后翻转每个单词。用两个指针记录每个单词的开头和结尾的位置。遇到’ ‘说明单词的结尾,需要调节指针。

另外注意的点是,字符串不能直接修改,需要转成list之后才能直接对每一位修改。

代码:

# -*- coding:utf-8 -*-
class Solution:
    def ReverseSentence(self, s):
        if not s: return s
        s = list(s)
        self.reverse(s, 0, len(s) - 1)
        start, end = 0, 0
        while start < len(s):
            if s[start] == ' ':
                start += 1
                end += 1
            elif end == len(s) or s[end] == ' ':
                self.reverse(s, start, end - 1)
                end += 1
                start = end
            else:
                end += 1
        return ''.join(s)

    def reverse(self, s, start, end):
        while start < end:
            s[start], s[end] = s[end], s[start]
            start += 1
            end -= 1

Date

2018 年 3 月 26 日 – 学车要早起,困= =