字符串中的单词反转【leetcode】

本题选自leetcode图解算法数据结构一书

你在与一位习惯从右往左阅读的朋友发消息,他发出的文字顺序都与正常相反但单词内容正确,为了和他顺利交流你决定写一个转换程序,把他所发的消息 message 转换为正常语序。

注意:输入字符串 message 中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。

示例 1:

输入: message = "the sky is blue"
输出: "blue is sky the"
示例 2:

输入: message = "  hello world!  "
输出: "world! hello"
解释: 输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
示例 3:

输入: message = "a good   example"
输出: "example good a"
解释: 如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。
 

提示:

1 <= message.length <= 10^4
message 中包含英文大小写字母、空格和数字
message 中至少有一个单词

法一:利用split依据空格对message进行划分

class Solution(object):
    def reverseMessage(self, message):
        """
        :type message: str
        :rtype: str
        """
        m=message.split(' ')
        t=[]
        for i in m:
            tmp=i.replace(' ','')#判断去除空格后的长度,如果全是空格就没有了
            if len(tmp):
                t.append(i)
        t.reverse()
        return " ".join(t)

字符串中的单词反转【leetcode】_第1张图片实际运行过程中,时间空间复杂度都不高

法二:双指针

注意点:

第一次写的时候,while循环里边没有加i>=0会导致第一个单词无法输出,因为少了这个条件会导致i<0在最后一次循环后小于0了,无法再次进入循环,导致少了一次

class Solution(object):
    def reverseMessage(self, message):
        """
        :type message: str
        :rtype: str
        """
        message=message.strip()
        i=j=len(message)-1
        t=[]
        while i>=0:
            while message[i]!=' ' and i>=0:
                i-=1
            t.append(message[i+1:j+1])#注意[]的区间是左闭右开
            while message[i]==' ' and i>=0:
                i-=1
            j=i
        
        return " ".join(t)

字符串中的单词反转【leetcode】_第2张图片

你可能感兴趣的:(leetcode)