首页 > 其他 > 详细

LeetCode--Reverse Words in a String

时间:2014-07-16 18:49:43      阅读:296      评论:0      收藏:0      [点我收藏+]
class Solution {
public:
    void reverseWords(string &s) {
        int len = s.length();
        if(len == 0)
            return;
        vector<string> res;
        int i = 0;
        int j = len-1;
        //去掉收尾的空格
        while(i < len && s[i] ==  )
            ++i;
        while(j >= 0 && s[j] ==  )
            --j;
        int k = i;//寻找一个单词
        while(i <= j)
        {
            k = i;
            while(i<=j && s[i]!= )
            {
                ++i;
            }
            res.push_back(s.substr(k,i-k));
            while(s[i]==  && i<=j)
                ++i;
        }
        if(res.empty())
        {
            s = "";
            return;
        }
        reverse(res.begin(),res.end());
        string m = res[0];
        for(int i=1;i<res.size();i++){  
            m+=" ";  
            m+=res[i];  
        }  
        s=m; 
    }
};

先删除前后的空格,多个空格合并为一个空格输出。

LeetCode--Reverse Words in a String,布布扣,bubuko.com

LeetCode--Reverse Words in a String

原文:http://www.cnblogs.com/cane/p/3845016.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!