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;
    }

};
相关推荐
王老师青少年编程15 小时前
2026年全国青少年信息素养大赛算法应用主题赛(C++赛项-初赛-赛前冲刺模拟卷1:文末附答案和解析)
c++·全国青少年信息素养大赛·答案·初赛·模拟卷·2026年·算法应用主题赛
alwaysrun15 小时前
C++之轻量级JSON序列库jsoncpp
c++·json·编程语言
咩咦15 小时前
C++学习笔记09:内联函数 inline
c++·学习笔记·inline·内联函数·宏函数
Genevieve_xiao15 小时前
【xjtuse】【数学建模】课程笔记(一)初等模型、图与网络
笔记·数学建模
计算机安禾15 小时前
【c++面向对象编程】第19篇:多继承与菱形继承(二):虚拟继承的内存模型与复杂性
开发语言·c++
OBiO201315 小时前
靶向肠道的腺相关病毒(AAV)血清型及启动子选择
笔记
star learning white15 小时前
xm电气工程5
笔记
思麟呀15 小时前
在C++基础上理解CSharp-1
开发语言·c++·c#
凉、介15 小时前
ARM GICv3 学习笔记(一)
arm开发·笔记·学习·嵌入式
学习,学习,在学习15 小时前
Q工控仪器程序框架设计详解(工控)
c++·qt·架构·qt5