C++ 反转字符串中的单词 III

给定一个字符串,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。
示例 1:
输入: “Let’s take LeetCode contest”
输出: “s’teL ekat edoCteeL tsetnoc”
注意:在字符串中,每个单词由单个空格分隔,并且字符串中不会有任何额外的空格。
利用迭代器遍历的方式

class Solution {
public:
    string reverseWords(string s) {
         string::iterator it1=s.begin();
        string::iterator it2=s.begin()+1;
        while(it2<s.end())
        {
            if(*it2==' ')
            {
                reverse(it1,it2);
                it1=it2+1;
            }
            ++it2;
        }
        //此时it2=s.end()
        reverse(it1,it2);//反转最后一个单词
        return s;
    }
};

你可能感兴趣的:(C++)