题目要求
输入一个句子,例如“I am a student.”,反转句子中单词的顺序,标点和字母处理方式一样, 但单词内的字符顺序不变,输出反转后的结果,如“student. a am I”。
解题分析
不同于书上的官方解法,在这里我们巧妙地利用字符串的相加和空格的判断来达到字符串反转的效果!
比较 “I am a student.” 和 “student. a am I”, 你会发现实际上就是把I,am依次放在了字符串的最后(变成am, I),我们按照字符串出现的顺序,以空格分割,先出现的放到最后,次出现的放到倒数第二位,依次遍历字符串,完成转换。
另外本题目是,整体反转,局部不反转(单词不反转),只是用一次stl的reverse函数是不够的,因为他是局部,整体全都反转!!
主要代码c++
class Solution {
public:
string ReverseSentence(string str) {
string res,tmp = ""; // res存放最后结果, tmp存放每一个小字符串的结果
for(unsigned int i = 0; i < str.size(); ++i)//无符号类型能保存2倍于有符号类型的正整数数据。
{
if(str[i] == ' ')
{
res = " " + tmp + res; // 每一个小块翻转
tmp = "";
}
else
tmp += str[i];
}
if(tmp.size()) // 因为最后一个小片段没办法用空格判断
res = tmp + res;
return res;
}
};
小tips: c++中的 单引号和双引号