zoukankan      html  css  js  c++  java
  • 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
        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
    ", 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位为符号位)

  • 相关阅读:
    Linux 文件取交集 并集 差集
    阿里花名推荐
    Linux bg fg命令的使用
    python导入自己创建的本地包报错
    数值计算方法
    数据库oracle回顾
    使用visualBox创建Centos/7,搭建docker,安装mysql,及远程连接
    git 合并分支到master
    git 本地文件修改错误,重新取回服务器历史版本
    三本不错的计算机专业书籍(需求分析,开发实务,恶意代码分析)
  • 原文地址:https://www.cnblogs.com/ice-image/p/10307490.html
Copyright © 2011-2022 走看看