数值统计 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) 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
Source
Recommend JGShining | We have carefully selected several similar problems for you: 2007 2005 2009 2010 2011
|
#include<stdio.h>
#include<malloc.h>
int main()
{
int n;
while(scanf("%d",&n)!=EOF&&n!=0)
{
double *shzu=(double*)malloc(sizeof(double)*n);
int i,Z,F,O;
Z=F=O=0;
for(i=0;i<n;i++)
{
scanf("%lf",&shzu[i]);
if(shzu[i]==0)
{
O++;
}
else if(shzu[i]>0)
{
Z++;
}
else F++;
}
printf("%d %d %d\n",F,O,Z);
free(shzu);
}
return 0;
}