zoukankan      html  css  js  c++  java
  • C语言中的正负数及其输出以及小数

    1、符号也是数字的一部分,也要在内存中体现出来。符号只是正负两种情况,用一位(Bit)就足以表示;C语言中规定,把内存的最高位作为符号位

    2、C语言中规定,在符号位中,用0表示正数、用1表示负数

    3、C语言允许我们这样做,如果不希望设置符号位,可以在数据类型前面加上unsigned关键字,

    例如:unsigned int b=1002;或 unsigned b=1002;

      这样,short、int、long中就没有符号位了,所有的位都用来表示数值,正数的取值范围更大了,这也意味着,使用了unsigned后只能表示正数,不能在表示负数了!加了unsigned的数字称为无符号数未加的数字称为有符号数

      printf不支持以八进制(%0)和十六进制(%x)形式输出有符号数,只有十进制用%d来表示有符号数。用%u来表示无符号数。

    4、工作原则:

      1)当以有符号数的形式输出时,printf会读取数字所占的内存,并把最高位作为符号位,把剩下的内存作为数值位。

      2)当以无符号数的形式输出时,printf也会读取数字所占的内存,并把所有内存都作为数值位对待。

    对于一个有符号的正数,它的符号位是0;当按照无符号数的形式读取时,符号位就变成了数值位,但该位恰巧是0而不是1;所以对数值不会产生影响,这就好比在一个数字前面加0,有多少个0都不会影响数字的值。

    可以说,“有符号的正数的最高位是0”这个巧合才使得%0和%x输出有符号数时才不会出错!

    5、注意:虽然部分编译器支持二进制数字的表示,但是却不能使用printf函数输出二进制,这一点比较遗憾!

      若要使输出的八进制或十六进制的前缀也输出,则要在%前加上 # 号。例如:%#0、%#x

    6、小数的输出:

      %e以指数形式输出float类型,输出结果中的e小写。

      %le以指数形式输出double类型,输出结果中的e小写。

     1)%g默认最多保留六位有效数字,包括整数部分和小数部分;%f和%e默认保留六位小数,只包括小数部分。

    2)%g不会再最后强加0来凑够有效数字的位数,而%f和%e会在最后强加0来凑足小数部分的位数

    7、数字的默认类型:对于整数,默认为int类型;对于小数,默认是double类型。

      1)在整数后面紧跟l或者L(不区分大小写)表明该数字是long类型

      2)在小数后面紧跟f或F表明数字是float类型

     

    8、小数和整数之间的相互赋值:

      1)将整数赋值给小数类型,在小数后面加0就可以了,加几个都无所谓哦!

      2)将小数赋值给整数类型,就得把小数部分丢掉,只能取整数部分,这会改变数字本身的值。直接丢掉小数部分,不是进行四舍五入

     由于将小数赋值给整数类型会“失真”,所以编译器一般会给出警告,让大家引起注意。 

  • 相关阅读:
    与非
    抄卡组
    数据结构》关于差分约束的两三事(BZOJ2330)
    刷题向》图论》BZOJ1179 关于tarjan和SPFA的15秒(normal)
    图论算法》关于tarjan算法两三事
    图论算法》关于SPFA和Dijkstra算法的两三事
    刷题向》DP》值得一做》关于对DP问题的充分考虑(normal)
    数据结构》关于线段树两三事(新手向)(工具向)
    图论算法》关于匈牙利算法的两三事
    关于羊和车的问题
  • 原文地址:https://www.cnblogs.com/YuanBo-China/p/10684852.html
Copyright © 2011-2022 走看看