行業(yè)網(wǎng)站建設(shè)費用百度seo推廣軟件
給你一個字符串 s ,請你反轉(zhuǎn)字符串中 單詞 的順序。
單詞 是由非空格字符組成的字符串。s 中使用至少一個空格將字符串中的 單詞 分隔開。
返回 單詞 順序顛倒且 單詞 之間用單個空格連接的結(jié)果字符串。
注意:輸入字符串 s中可能會存在前導空格、尾隨空格或者單詞間的多個空格。返回的結(jié)果字符串中,單詞間應當僅用單個空格分隔,且不包含任何額外的空格。
示例 1:
輸入:s = “the sky is blue”
輸出:“blue is sky the”
示例 2:
輸入:s = " hello world "
輸出:“world hello”
解釋:反轉(zhuǎn)后的字符串中不能存在前導空格和尾隨空格。
示例 3:
輸入:s = “a good example”
輸出:“example good a”
解釋:如果兩個單詞間有多余的空格,反轉(zhuǎn)后的字符串需要將單詞間的空格減少到僅有一個。
提示:
1 <= s.length <= 104
s 包含英文大小寫字母、數(shù)字和空格 ’ ’
s 中 至少存在一個 單詞
class Solution {
public:string reverseWords(string s) {vector<string> res;s = s.substr(s.find_first_not_of(' '), s.find_last_not_of(' ') + 1);// 使用 istringstream 進行字符串分割istringstream iss(s);string word;while (iss >> word) {res.push_back(word);}// 逆序拼接結(jié)果字符串string result;for (int i = res.size() - 1; i >= 0; i--) {if (i > 0) result += res[i] + ' ';else result += res[i];}return result;}
};
一開始按照最笨的方式寫的,結(jié)果MLE了,貼在這里謹記:
vector<string> res;int i = 0;while (i < s.size() && s[i] == ' ') i++;int j = s.size() - 1;while (j >= 0 && s[j] == ' ') j--;s = s.substr(i, j - i + 1);cout<<s<<endl;for(int i = 0; i < s.size(); i ++) {int j = i;while(j < s.size() && s[j] != ' ') j ++;res.push_back(s.substr(i, j - i));j --;while(s[j] == ' ') j ++;i = j;}string ss;for(int i = res.size() - 1; i >= 0; i --) {if(i > 0) ss += res[i] + ' ';else ss += res[i];}