《剑指offer》面试题58 - I. 翻转单词顺序

问题描述

输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student. ",则输出"student. a am I"。

 

示例 1:

输入: "the sky is blue"
输出: "blue is sky the"
示例 2:

输入: "  hello world!  "
输出: "world! hello"
解释: 输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
示例 3:

输入: "a good   example"
输出: "example good a"
解释: 如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。
 

说明:

无空格字符构成一个单词。
输入字符串可以在前面或者后面包含多余的空格,但是反转后的字符不能包括。
如果两个单词间有多余的空格,将反转后单词间的空格减少到只含一个。

代码

class Solution {
public:
    string reverseWords(string s) {
        int n = s.size()-1;
        string ans;
        while(n >= 0)
        {
            while(n >= 0 && s[n] == ' ')
                --n;
            if(n < 0)break;
            if(ans.size()!=0)ans += ' ';
            string tmp;
            while(n >= 0 && s[n] != ' ')
            {
                tmp += s[n];
                --n;
            }
            reverse(tmp.begin(),tmp.end());
            ans += tmp;
        }
        return ans;
    }
};

结果:

执行用时 :12 ms, 在所有 C++ 提交中击败了56.56%的用户
内存消耗 :8.5 MB, 在所有 C++ 提交中击败了100.00%的用户
posted @ 2020-05-01 08:37  曲径通霄  阅读(93)  评论(0编辑  收藏  举报