LeetCode Reverse Words in a String

LeetCode解题之Reverse Words in a String


原题

将一个字符串依照单词的力度进行反转。例如将”the sky is blue”转化为”blue is sky the”。

注意点:

  • 原始字符串中可能首位有空格,结果不要有这些空格
  • 原始字符串单词间可能有多个空格,结果单词间只需有一个空格

例子:

输入: s = “the sky is blue”

输出: “blue is sky the”

解题思路

用Python解决这个问题有些特殊,Python中的字符串是不可变的数据类型,而比较pythonic的写法是直接一行代码,先把字符串按空格分开,反转后用空格连接起来。

从算法层面讲,这道题希望做到原地完成字符串的反转。我们可以通过以下几步做到:

  • 将整个字符串直接反转
  • 遍历字符串单独将每个单词反转,注意反转的同时可以通过移位来除去不必要的空格

AC源码

class Solution(object):
    def reverseWords(self, s):
        """
        :type s: str
        :rtype: str
        """
        return " ".join(s.split()[::-1])


if __name__ == "__main__":
    assert Solution().reverseWords("the sky is blue ") == "blue is sky the"

欢迎查看我的Github (https://github.com/gavinfish/LeetCode-Python) 来获得相关源码。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值