当前位置: 代码迷 >> 综合 >> 【LeetCode】151. 翻转字符串里的单词 python,C++stringstream,先翻转整体再反转局部
  详细解决方案

【LeetCode】151. 翻转字符串里的单词 python,C++stringstream,先翻转整体再反转局部

热度:45   发布时间:2023-11-19 17:03:59.0
151. 翻转字符串里的单词
给定一个字符串,逐个翻转字符串中的每个单词。
示例 1:
输入: "the sky is blue"
输出: "blue is sky the"示例 2:
输入: " hello world! "
输出: "world! hello"
解释: 输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括示例 3:
输入: "a good example"
输出: "example good a"
解释: 如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。说明:
无空格字符构成一个单词。
输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。

python解法 最简单

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

C++stringstream的使用

strngstream 可以用于分割被空格、制表符等符号分割的字符串

class Solution {
    
public:string reverseWords(string s) {
    stringstream ss;string ans="",temp;ss<<s;while(ss>>temp){
    ans=" "+temp+ans;}if(ans!="")ans.erase(ans.begin());return ans; }
};

先翻转整体再翻转局部

class Solution {
    public:string reverseWords(string s) {
    // 反转整个字符串reverse(s.begin(), s.end());int n = s.size();int idx = 0;for (int start = 0; start < n; ++start) {
    if (s[start] != ' ') {
    // 填一个空白字符然后将idx移动到下一个单词的开头位置if (idx != 0) s[idx++] = ' ';// 循环遍历至单词的末尾int end = start;while (end < n && s[end] != ' ') s[idx++] = s[end++];// 反转整个单词reverse(s.begin() + idx - (end - start), s.begin() + idx);// 更新start,去找下一个单词start = end;}}s.erase(s.begin() + idx, s.end());return s;}
};