您的位置:首页 > 其它

LeetCode--Reverse Words in a String

2014-07-15 16:08 288 查看
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;
}
};


先删除前后的空格,多个空格合并为一个空格输出。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: