leetcode 反转单词

想一下,我们将整个字符串都反转过来,那么单词的顺序指定是倒序了,只不过单词本身也倒序了,那么再把单词反转一下,单词不就正过来了。

所以解题思路如下:

  • 移除多余空格
  • 将整个字符串反转
  • 将每个单词反转

举个例子,源字符串为:"the sky is blue "

  • 移除多余空格 : "the sky is blue"
  • 字符串反转:"eulb si yks eht"
  • 单词反转:"blue is sky the"

这样我们就完成了翻转字符串里的单词。

cpp 复制代码
class Solution {
public:
    void removespace(string &s){
     int slow =0;
        for(int i=0;i<s.size();i++){
            if(s[i]!=' '){
                if(slow!=0){s[slow++]=' ';}   
               while(i<s.size()&&s[i]!=' '){
                    s[slow++]=s[i++];
                }
            }
            
        }
        s.resize(slow);
    
    } 
    

    
    string reverseWords(string s) {
        removespace(s);
        reverse(s.begin(),s.end());
        auto start=s.begin();
        int count=0;
                for(int i=0;i<=s.size();i++){
         if(s[i]==' '||i==s.size())
            {
             reverse(start,s.begin()+i);
             start=(s.begin()+i+1);
             
         }
        }
        return s;

    }
};
相关推荐
setmoon2149 小时前
C++中的观察者模式实战
开发语言·c++·算法
2403_835568479 小时前
C++代码规范化工具
开发语言·c++·算法
tankeven9 小时前
HJ138 在树上游玩
c++·算法
lihihi10 小时前
P1209 [USACO1.3] 修理牛棚 Barn Repair
算法
weixin_3875342210 小时前
Ownership - Rust Hardcore Head to Toe
开发语言·后端·算法·rust
xsyaaaan10 小时前
leetcode-hot100-链表
leetcode·链表
庞轩px10 小时前
MinorGC的完整流程与复制算法深度解析
java·jvm·算法·性能优化
Queenie_Charlie11 小时前
Manacher算法
c++·算法·manacher
闻缺陷则喜何志丹11 小时前
【树的直径 离散化】 P7807 魔力滋生|普及+
c++·算法·洛谷·离散化·树的直径
AI_Ming11 小时前
Seq2Seq-大模型知识点(程序员转行AI大模型学习)
算法·ai编程