您的位置:首页 > 其它

HDOJ 2008 数值统计

2014-07-22 10:02 393 查看


数值统计

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)

Total Submission(s): 53403 Accepted Submission(s): 27342



Problem Description

统计给定的n个数中,负数、零和正数的个数。

Input

输入数据有多组,每组占一行,每行的第一个数是整数n(n<100),表示需要统计的数值的个数,然后是n个实数;如果n=0,则表示输入结束,该行不做处理。

Output

对于每组输入数据,输出一行a,b和c,分别表示给定的数据中负数、零和正数的个数。

Sample Input

6 0 1 2 3 -1 0
5 1 2 3 4 0.5
0


Sample Output

1 2 3
0 0 5


Author

lcy

第一次代码:
#include <stdio.h>
int main ()
{
int n,b,c,d;
int a[100];
while (scanf("%d",&n),n!=0)
{
b=c=d=0;
for (int i=0;i<n;i++)
scanf ("%d",&a[i]);
for (int i=0; i<n; i++)
{
if (a[i]>0)    b++;
else if (a[i]<0)   c++;
else d++;
}
printf ("%d %d %d\n",b,c,d);
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111292142014-07-22 09:14:29Output Limit Exceeded2008125MS220K404 BC++Hidden Secret
第二次代码:
#include <stdio.h>
int main ()
{
int a,n,b,c,d;
while (scanf("%d",&n),n!=0)
{
b=c=d=0;
while (n--)
{
scanf ("%d",&a);
if (a>0)    b++;
else if (a<0)   c++;
else d++;
}
printf ("%d %d %d\n",b,c,d);
}
return 0;
}

Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111292712014-07-22 09:19:11Time Limit Exceeded20081000MS220K337 BC++Hidden Secret
第三次代码:

#include <stdio.h>
int main ()
{
int n,b,c,d;
double a;
while (scanf("%d",&n),n!=0)
{
b=c=d=0;
while (n--)
{
scanf ("%lf",&a);
if (a>0)    b++;
else if (a<0)   c++;
else d++;
}
printf ("%d %d %d\n",b,c,d);
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111294022014-07-22 09:27:23Wrong Answer200815MS260K351 BC++Hidden Secret
第四次代码:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
int n,i,j,k;
double a;

while(scanf("%d",&n)==1)
{

if(n==0)    break;
else
{
int i=0,j=0,k=0;
for(int l=1; l<=n; l++)
{
scanf("%lf",&a);
if(a<0) i++;
else if(a==0)   j++;
else if(a>0)    k++;
}
printf("%d %d %d\n",i,j,k);
}
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111295512014-07-22 09:36:02Accepted20080MS260K515 BC++Hidden Secret
第五次代码:
#include <stdio.h>
int main ()
{
int i,j,k,n;
double a;
while (scanf ("%d",&n),n!=0)
{
i=j=k=0;
while (n--)
{
scanf("%lf",&a);
if (a>0)    i++;
else if (a==0)  j++;
else    k++;
}
printf ("%d %d %d\n",i,j,k);
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111295632014-07-22 09:36:36Wrong Answer20080MS260K354 BC++Hidden Secret
第六次代码:
#include <stdio.h>
int main ()
{
int i,j,k,n;
double a;
while (1)
{
scanf ("%d",&n);
if(n!=0)
{
i=j=k=0;
while (n--)
{
scanf("%lf",&a);
if (a>0)    i++;
else if (a==0)  j++;
else    k++;
}
printf ("%d %d %d\n",i,j,k);
}
else break;
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111296012014-07-22 09:38:50Wrong Answer20080MS260K458 BC++Hidden Secret
第七次代码:
#include <stdio.h>
int main ()
{
int i,j,k,n;
double a;
while (scanf ("%d",&n)==1)
{
if(n!=0)
{
i=j=k=0;
while (n--)
{
scanf("%lf",&a);
if (a>0)    i++;
else if (a==0)  j++;
else    k++;
}
printf ("%d %d %d\n",i,j,k);
}
else break;
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111298012014-07-22 09:48:26Wrong Answer20080MS260K449 BC++Hidden Secret
第八次代码:
#include <stdio.h>
int main ()
{
int i,j,k,n;
double a;
while (scanf ("%d",&n)==1)
{
if(n!=0)
{
i=j=k=0;
for (int b=0;b<n;b++)
{
scanf("%lf",&a);
if (a>0)    i++;
else if (a==0)  j++;
else    k++;
}
}
else break;
printf ("%d %d %d\n",i,j,k);
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111298582014-07-22 09:51:32Wrong Answer20080MS260K455 BC++Hidden Secret
第九次代码:
#include <iostream>
using namespace std;
int main(){
int m,i;
double n;
while(cin>>m)
{
if(m == 0)
break;
int a = 0, b = 0, c = 0;
for (i = 0; i < m; i++)
{
cin>>n;
if(n < 0)
a++;
else if(n > 0)
c++;
else b++;
}
cout<<a<<" "<<b<<" "<<c<<endl;
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111299372014-07-22 09:54:50Accepted200815MS312K490 BC++Hidden Secret
第十次代码:
#include <stdio.h>
int main ()
{
int b,c,d,n;
double a;
while (scanf ("%d",&n))
{

b=c=d=0;
if(n==0)    break;
else
{
for (int i=0; i<n; i++)
{
scanf("%lf",&a);
if (a>0)    b++;
else if (a==0)  c++;
else    d++;
}
printf ("%d %d %d\n",b,c,d);
}
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111300022014-07-22 09:58:23Wrong Answer20080MS260K459 BC++Hidden Secret
第十一次代码:
#include <stdio.h>
int main ()
{
int b,c,d,n;
double a;
while (scanf ("%d",&n))
{

b=c=d=0;
if(n==0)    break;
else
{
for (int i=0; i<n; i++)
{
scanf("%lf",&a);
if (a<0)    b++;
else if (a==0)  c++;
else    d++;
}
printf ("%d %d %d\n",b,c,d);
}
}
return 0;
}


Run IDSubmit TimeJudge StatusPro.IDExe.TimeExe.MemoryCode Len.LanguageAuthor
111301132014-07-22 10:02:34Accepted20080MS260K459 BC++Hidden Secret
总结:
呼~终于过了……各种坑爹问题。首先我没注意到输入数字的类型是double型,其次我在考虑累加器上还是有点问题。感觉这次最大问题是在条件判断的误读上,人家输出是有顺序的,结果我忘了这一点,随便就输出,导致错到最后!!!水题注意细节!!!!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: