翻转单词顺序列

来源:互联网 发布:综漫 收集数据做主神 编辑:程序博客网 时间:2024/06/04 01:12

题目描述

牛客最近来了一个新员工Fish,每天早晨总是会拿着一本英文杂志,写些句子在本子上。同事Cat对Fish写的内容颇感兴趣,有一天他向Fish借来翻看,但却读不懂它的意思。例如,“student. a am I”。后来才意识到,这家伙原来把句子单词的顺序翻转了,正确的句子应该是“I am a student.”。Cat对一一的翻转这些单词顺序可不在行,你能帮助他么?

下面用到了string类中的直接“+”连接字符串的功能

/*遍历string中每个单词的过程中,采用类似链表头插法的方法将单词依次插入当前string的前面去*/class Solution {public:    string ReverseSentence(string str) {        int len=str.size();        string temp="",res="";        if(len<=1) return str;        for(int i=0; i<len; ++i)            {            if(str[i]==' '){                res=" "+temp+res;                temp="";            }            else temp+=str[i];        }        if(temp.size()) res=temp+res;        return res;    }};

下面的reverse(begin(),end())函数,将区间内的字符颠倒过来,其中begin()指向第一个字符,end()指向字符串的最后一个位置的尾后指针。

/*先将整个句子翻转,然后再翻转每个单词*//*class Solution {public:    string ReverseSentence(string str) {        if(str.size()<=1) return str;        reverse(str.begin(),str.end());        string::iterator begin=str.begin(),end=begin;        while(end!=str.end())            {            while(*end!=' '&&end!=str.end())                ++end;            if(begin<end) reverse(begin,end);            if(end!=str.end())                {                  ++end;                  begin=end;            }        }        return str;    }};





原创粉丝点击