您的位置:首页 > 其它

杭电ACM 1062: Text Reverse

2017-11-10 20:37 411 查看
出处http://blog.csdn.net/always2015/article/details/45364713



这一道题不是很难,主要在于注意字符串的存取方式就成功了一大半,再者就是如何读取单个单词然后反向输出这也是关键。在输入字符串的时候我用到了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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: