原题描述
问题 1094: 字符串的输入输出处理
时间限制: 1Sec 内存限制: 64MB 提交: 10667 解决: 3704
题目描述
字符串的输入输出处理。
输入
第一行是一个正整数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<iostream>
#include<stdio.h>
#include<string.h>
using namespace std;
int main()
{
char a[1000];
int n;
cin>>n;
getchar();
while(n--)
{
gets(a);
puts(a);
cout<<endl; //cout<<endl;
}
while(gets(a))
{
int len=strlen(a);
for(int i=0;i<len;i++)
{
if(a[i]==' ')
{
cout<<endl;cout<<endl;
}
else
{
cout<<a[i];
}
}
cout<<endl; cout<<endl;
}
return 0;
}
最佳代码
#include<stdio.h>
#include<string.h>
int main()
{
char a[1001];
int n;
scanf("%d",&n);
getchar();
for(int i=0;i<n;i++)
{gets(a);puts(a);printf("\n");}
while(scanf("%s",a)!=EOF)//最佳代码,这样才是最棒的,巧妙运用了输入输出
{
printf("%s\n",a);
printf("\n");
}
return 0;
}
总结
1.还是最佳代码要好很多,因为巧妙运用了gets与%s的区别,我写的虽然对,但执行效率很低很低,如果卡时间就不行了
2.scanf("%s",a),这里a前面没有&了