HDOJ 2008 数值统计

数值统计

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型,其次我在考虑累加器上还是有点问题。感觉这次最大问题是在条件判断的误读上,人家输出是有顺序的,结果我忘了这一点,随便就输出,导致错到最后!!!水题注意细节!!!!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值