0
点赞
收藏
分享

微信扫一扫

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


【剑指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 日 – 学车要早起,困= =



举报

相关推荐

0 条评论