时间限制: 1Sec 内存限制: 64MB
题目描述
字符串的输入输出处理。
输入
第一行是一个正整数N,最大为100。之后是多行字符串(行数大于N), 每一行字符串可能含有空格,字符数不超过1000。
输出
先将输入中的前N行字符串(可能含有空格)原样输出,再将余下的字符串(不含有空格)以空格或回车分割依次按行输出。每行输出之间输出一个空行。
样例输入
2
www.dotcpp.com DOTCPP
A C M
D O T CPP
样例输出
www.dotcpp.com DOTCPP
A C M
D
O
T
CPP
代码
正确代码:
#include<stdio.h>
#include<string.h>
char s[1000];
int main()
{
int n,i=0,j,k,flag=1;
scanf("%d", &n);
getchar();
for(i=0;1;i++)
{
if(i<n)
{
gets(s);
puts(s); //puts()输出字符串单独占一行,结束换行
}
else
{
if(scanf("%s", s)+1);
else break; //EOF结束
printf("%s\n", s);
}
printf("\n");
}
return 0;
}
错误代码一:
#include<stdio.h>
#include<string.h>
char s[1000];
int main()
{
int n,i,j;
scanf("%d", &n);
getchar();
for(i=0;i<n;i++){
gets(s);
printf("%s\n\n", s);
}
while(scanf("%s", s)+1){
if(*s==' '||*s=='\n') printf("\n\n");
else printf("%s", s);
}
return 0;
}
输出情况:将前n个字符串在输入结束后原样输出,以后每个字符串全部都是去掉空格输出
错误代码二
#include<stdio.h>
#include<string.h>
char s[100][1000];
int main()
{
int n,i=0,j,k,flag=1;
scanf("%d", &n);
getchar();
for(i=0;1;i++)
{
j=0;
do{
if(scanf("%c", &s[i][j])+1);
else flag=0;
}while(s[i][j++]!='\n');
if(!flag) break;
s[i][j]='\0';
if(i<n) printf("%s", s[i]);
else{
for(k=0;s[i][k]!='\0';k++)
if(s[i][k]==' ') printf("\n\n");
else printf("%c", s[i][k]);
}
printf("\n");
}
return 0;
}
该程序是模拟读取字符串进行读取
输出情况:将前n个字符串在输入结束后原样输出,以后每个字符串按照示例输出
但是在Judge中出现时间超限的情况