由题目意思可知道容易出现4种情况。
1.在输入的过程中可以记录负数的个数,零的个数。
2.我们正数的和。定义为float类型防止在后面运算的过程中产生数据失去。
2.可以出现3种情况
-1 ,-2,-4,-5 全部都是负数的情况
-1,-2,-3,-4,0,0 没有正数的情况
1,2,3,4,5,全部都是正数的情况
1,2,3,4,5 ,0,0,没有负数的情况
1 ,2,-1,-2,有正数有负数
1 , 2,-1,-2,0,5 有正数有负数有0的情况
0,0,0,,0,0,0,全部都是0的情况
1.输出负数的个数在输入的过程中有记录。
2.当记录的正数是0(负数的个数+0的个数==n)的时候平均值直接输出0.0
3.有负数有正数有0的时候,计算正数的个数。用我们记录的正数的和去除以正数的个数。
具体代码:
#include <stdio.h>
int main()
{
//输入
int n=0;
scanf("%d",&n);
//输入数值
int count=0;
float sum=0;
int zero=0;
int number[2000];
for(int i=0;i<n;i++)
{
scanf("%d",number+i);
if(number[i]<0)
{
count++;
}
else if(number[i]>0)
{
sum+=number[i];
}
else
{
zero++;
}
}
if(zero==n)
{
printf("%d %.1f",0,0.0);
}
if(zero==0)
{
float averge=(sum/(n-count));
printf("%d %.1f",count,averge);
}
if((zero<n)&&(zero>0))
{
float averge=(sum/(n-count-zero));
printf("%d %.1f",count,averge);
}
return 0;
}