翻转单词顺序列
来源:互联网 发布:综漫 收集数据做主神 编辑:程序博客网 时间: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; }};
阅读全文
0 0
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- 翻转单词顺序列
- Ajax全接触
- 1575:16进制A+B
- Python_进程(二)
- java公平锁源码解读
- 深度学习最全优化方法总结比较(SGD,Adagrad,Adadelta,Adam,Adamax,Nadam)
- 翻转单词顺序列
- 2017.9.3
- [BZOJ]5000: OI树 倍增
- 179.LK's problem
- 指针和数组与sizeof运算符(嵌入式笔试必考题)
- 面试技巧,如何通过索引说数据库优化能力,内容来自Java web轻量级开发面试教程
- SER2016 DIV1 B, K 题解
- Java IO : 流,以及装饰器模式在其上的运用
- HDU