Leetcode刷题笔记题解(C++):LCR 181. 字符串中的单词反转

思路:根据栈的原理先进后出,使用栈来依次保存每个单词,然后再依次从栈中取出每个单词

cpp 复制代码
class Solution {
public:
    string reverseMessage(string message) {
        int left = 0;
        int right = message.size()-1;
        //消除字符串前后多余的空格,比如字符串"  hello world!  "
        while(left<=right&&message[left]==' ') left++;
        while(right>=left&&message[right]==' ') right--;
        stack<string>sk;
        string str;//用于保存单个字符
        //从第一个单词开始压入栈中
        while(left<=right){
            //遇到空格并且前一个字符不是空格则判定之前的就为单个单词,str.size()>0用于判定之前的一个字符不为空格
            if(message[left]==' '&&str.size()>0){
                sk.push(str);
                str.clear();
            }
            //生成单词
            else if(message[left]!=' ') str+=message[left];
            left++;
        }
        //最后一个单词遇不到空格了,单独压入栈中
        sk.push(str);
        string ret;
        while(!sk.empty()){
            ret+=sk.top();//从上至下取出栈中每个单词
            ret+=" ";//每个单词之后添加空格
            sk.pop();//弹栈
        }
        ret.pop_back();//最后一个单词之后跟了一个空格,弹出空格
        return ret;
    }

};
相关推荐
珊瑚里的鱼几秒前
C++14 和 C++17 的核心新特性
开发语言·c++
中屹指纹浏览器3 分钟前
2026指纹浏览器集群分布式部署架构、负载均衡与机房硬件适配方案
经验分享·笔记
小欣加油3 分钟前
leetcode169 多数元素
数据结构·c++·算法·leetcode·职场和发展
影寂ldy13 分钟前
C# 多接口、同名冲突、显式实现、接口继承 完整笔记
java·笔记·c#
大G的笔记本14 分钟前
生产级 Spring Boot 网关完整实现方案
java·笔记·gateway
zxw61025 分钟前
UFOMap代码Debug
c++
fpcc26 分钟前
工具使用—CMake文件中的常见变量
c++
searchforAI28 分钟前
利用AI翻译视频做双语笔记,一套视频翻译到知识库沉淀的完整方案
人工智能·笔记·gpt·音视频·语音识别·知识图谱·机器翻译
liu-yonggang29 分钟前
MISRA C++:2008 — Guidelines for the use of the C++ language in critical systems
c++
SHARK_pssm31 分钟前
【数据结构——双向链表】
数据结构·经验分享·笔记·链表