杭电ACM 1062: Text Reverse
2015-04-29 11:54
197 查看
原创作品 转载请注明出处/article/10717357.html
这一道题不是很难,主要在于注意字符串的存取方式就成功了一大半,再者就是如何读取单个单词然后反向输出这也是关键。在输入字符串的时候我用到了getline()函数,这个函数的参数是一个输入和一个string对象,函数从给定的输入流中读入内容知道遇到换行符为止(注意换行符也被读进来了),然后把所有的内容都读入到那个string对象里面去(注意不存换行符),getline()只要遇到换行符就结束读取操作并返回结果,哪怕一开始就输入的是换行符也是如此。如果一开始输入的是换行符吗,那么所得的结果就是一个空串string。我的AC代码如下:
这一道题不是很难,主要在于注意字符串的存取方式就成功了一大半,再者就是如何读取单个单词然后反向输出这也是关键。在输入字符串的时候我用到了getline()函数,这个函数的参数是一个输入和一个string对象,函数从给定的输入流中读入内容知道遇到换行符为止(注意换行符也被读进来了),然后把所有的内容都读入到那个string对象里面去(注意不存换行符),getline()只要遇到换行符就结束读取操作并返回结果,哪怕一开始就输入的是换行符也是如此。如果一开始输入的是换行符吗,那么所得的结果就是一个空串string。我的AC代码如下:
#include <iostream> #include<string> #include <stdio.h> using namespace std; int main(void) { int t,length,count=0; string input_str; cin>>t; //将换行符读取,否则会出错 getchar(); for(int i=0; i<t; i++) { //将输入的字符串存储到string 里 getline(cin,input_str); //获取字符串的长度 length=input_str.size(); //在字符串最后加一个空字符,在后面做结尾判断 input_str[length]=' '; //遍历整个字符串 for(int j=0; j<=length; j++) { //统计字符串里面每个英文单词的长度 if(input_str[j]!=' ') { ++count; } else { //反向输出每个英文单词 for(int k=j-1; k>=j-count; k--) { cout<<input_str[k]; } //注意:在最后一个单词输出结束之后,后面不加空格 if(j!=length) cout<<" "; count=0; } } //输出完后换行 cout<<endl; } return 0; }
相关文章推荐
- 杭电ACM 1062: Text Reverse
- 杭电acm刷题(3):1062,Text Reverse 标签: 杭电acm 2017-05-15 08:26 126人阅读 评论(0)
- 杭电acm刷题(3):1062,Text Reverse
- 杭电1062 之 Text Reverse
- ACM--字母反转--HDOJ 1062--Text Reverse--字符串
- Text Reverse(杭电oj1062)
- 杭电OJ-1062_Text Reverse
- 杭电 1062 Text Reverse
- 杭电oj1062 Text Reverse
- 杭电ACM-Text Reverse
- 杭电OJ1062 Text Reverse
- 【杭电】[1062]Text Reverse
- 杭电1062 Text Reverse
- 杭电 HDU 1062 Text Reverse
- 杭电水题--Text Reverse 1062
- 杭电1062-Text Reverse
- 杭电ACM 1062
- 杭电OJ1062-Text Reverse
- 杭电 HDU 1247 ACMHat’s Words(trie树 或着STL)
- 杭电ACM 2025 查找最大元素