统计给定的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
1 #include <cstdio> 2 using namespace std; 3 int main(){ 4 int n; 5 while(scanf("%d", &n) == 1 && n){ 6 int positive = 0; 7 int zero = 0; 8 int negative = 0; 9 double temp = 0.0; 10 for(int i = 0; i < n; i++){ 11 scanf("%lf", &temp); 12 if(temp == 0){ 13 zero++; 14 }else if(temp > 0){ 15 positive++; 16 }else{ 17 negative++; 18 } 19 } 20 printf("%d %d %d\n", negative, zero, positive); 21 } 22 return 0; 23 }
(1)printf的%f说明符既可以输出float型又可以输出double型。
根据“默认参数提升”规则(在printf这样的函数的可变参数列表中,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到双精度数。
(2)scanf对于float类型必须用%f,double必须用%lf,对于scanf,情况就完全不同了,它接受指针,这里没有类似的类型提升。
(通过指针)向float存储和向double存储大不一样,因此,scanf区别%f和%lf。
(3)事实上,printf中没有定义%lf,但是很多系统可能会接受它。要确保可移植性,就要坚持使用%f。
建议大家使用double类型时,用%lf输入,%f输出避免出错。
float占32位,double占64位,(52位为系数位 11位为指数部分,1位为符号位)