C语⾔float和double输⼊问题
统计给定的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
html里的float是什么意思Sample Output
1 2 3
0 0 5
1 #include <cstdio>
2using namespace std;
3int main(){
4int n;
5while(scanf("%d", &n) == 1 && n){
6int positive = 0;
7int zero = 0;
8int negative = 0;
9double temp = 0.0;
10for(int i = 0; i < n; i++){
11 scanf("%lf", &temp);
12if(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 }
22return0;
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位为符号位)
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论