杭电水题--Text Reverse 1062
2013-06-01 13:19
274 查看
没事水几个题目,结果。。呵呵,遇到了点小问题,拿来与发大家分享下
题目很简单,就是给多行字符串,,把其中的单词翻转,做了半天都是PE问题,仔细研究了下发现了问题:
一看是要分割字符串,c++又没有正则支持,想到了用string流,通过>>操作符来略掉空格等字符,代码中的sin.get和sin.putback分别得到下一个字符和把当前得到的字符回退给输入流,这里为什么错了呢,注意string流初始话的时候是通过gets函数得到的字符数组,这里边匹配不到\n,而且sin.get函数读到'\0'的时候就会返回'-1',所以不能用这种方法,即使在后边加上判断换行的代码,也还是PE,跟踪代码过去,gets函数之后用getchar得到的并不是换行,好像gets直接吃掉了换行,这样仅仅提取单词是可以的,但是如果考虑中间空字符的话,这样就很麻烦了,反正至少我纠结了好几个钟头了,还是不行。算了放弃了,纠结这真没啥意思,看到一个很简洁的代码,就当学习了吧。
题目很简单,就是给多行字符串,,把其中的单词翻转,做了半天都是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; }
相关文章推荐
- 杭电ACM 1062: Text Reverse
- HDU 1062 Text Reverse(水题)
- 杭电 HDU 1062 Text Reverse
- 杭电acm刷题(3):1062,Text Reverse 标签: 杭电acm 2017-05-15 08:26 126人阅读 评论(0)
- Hdoj 1062 text reverse(水题)
- 杭电OJ1062-Text Reverse
- 杭电acm刷题(3):1062,Text Reverse
- 【杭电】[1062]Text Reverse
- 杭电1062 Text Reverse
- 杭电1062 之 Text Reverse
- Text Reverse(杭电oj1062)
- 杭电OJ1062 Text Reverse
- 杭电oj1062 Text Reverse
- HDU 1062 Text Reverse 水题 字符串处理
- hdu_1062 Text Reverse(水题)
- 杭电1062-Text Reverse
- 杭电OJ-1062_Text Reverse
- 杭电 1062 Text Reverse
- 杭电ACM 1062: Text Reverse
- HDU-1062-Text Reverse(细节题)