杭电水题--Text Reverse 1062

没事水几个题目,结果。。呵呵,遇到了点小问题,拿来与发大家分享下

       题目很简单,就是给多行字符串,,把其中的单词翻转,做了半天都是PE问题,仔细研究了下发现了问题:

while(gets(tmp))
		{
				string str(tmp);
				istringstream sin(str);
				string tm;
				string res;				
				while(sin>>tm)
				{
					reverse(tm.begin(),tm.end());
					char c;
					res+=tm;
					while( c=sin.get())
					{
						if(c == ' '|| c=='\t' || c=='\n')
							res+=c;
						else
						{
							sin.putback(c);
							break;
						}
					}
				}
				if(sin.peek()=='\n')
					res+='\n';
					printf("%s",res.c_str());
			}

一看是要分割字符串,c++又没有正则支持,想到了用string流,通过>>操作符来略掉空格等字符,代码中的sin.get和sin.putback分别得到下一个字符和把当前得到的字符回退给输入流,这里为什么错了呢,注意string流初始话的时候是通过gets函数得到的字符数组,这里边匹配不到\n,而且sin.get函数读到'\0'的时候就会返回'-1',所以不能用这种方法,即使在后边加上判断换行的代码,也还是PE,跟踪代码过去,gets函数之后用getchar得到的并不是换行,好像gets直接吃掉了换行,这样仅仅提取单词是可以的,但是如果考虑中间空字符的话,这样就很麻烦了,反正至少我纠结了好几个钟头了,还是不行。算了放弃了,纠结这真没啥意思,看到一个很简洁的代码,就当学习了吧。

#include <stdio.h>
#include <string.h>
char word[1005];
int main(void)
{	
	//reopen("a.txt","r",stdin);
	//freopen("b.txt","w",stdout);
	int n;
	scanf("%d", &n);	
	while(scanf("%s", word) != EOF)
	{
		for(int i=strlen(word)-1; i >= 0; i--)		
			putchar(word[i]);
		char c;
		while( c=getchar(), c == ' ' || c=='\t' || c=='\n' )
			putchar(c);
		ungetc(c, stdin);
	}
	return 0;
}


你可能感兴趣的:(杭电水题--Text Reverse 1062)