题解 | #翻转单词序列#

翻转单词序列

https://www.nowcoder.com/practice/3194a4f4cf814f63919d0790578d51f3

class Solution {
public:
    string ReverseSentence(string str) {
        if(str.size() == 0)
            return str;
        reverse(str.begin(),str.end());
        int n = str.size();
        for(int i = 0,j = 0; j<=n; j++)
        {
            if(str[j] == ' ' || j==n)
            {
                reverse(str.begin() + i,str.begin() + j);
                i = j+1;
            }
        }
        return str;
    }
};
解题思路就是反转再反转。
第一步,将其从头到尾反转一遍。原文为liming. am i world hello。。。。。。将变为olleh dlrow i ma .gnimil
第二步,一个窗格从头到尾扫描,框住单词就将其反转。即一个标定单词的起始字母l,另一个标定末尾,当遇到空格就停止,然后反转这两个标定的内容olleh将变为hello,然后将标定起始位置移动到第二个单词处(其实就是标定的末尾位置+1),开始第二单词的反转,直到遍历结束
全部评论

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务