c语言浮点舍入错误是什么意思,C语言中浮点数向零舍入取整的方法

之前没想过这个问题,今天做题时碰到了,想了半天没想明白,就上网开始查,结果查了一圈也没发现什么靠谱的答案。没办法,只能在角落里慢慢硬憋出个答案了。

忽然想起来既然都是往0上靠,其实也就是正数去掉小数,负数去小数绝对值加一,于是忽然想起来C还有个unsigned可以用!欣喜若狂地试了一下,发现完美实现了向0舍入的功能!

思路就是先把double强转成unsigned,这样就把负数补到正数上去了,顺便也去掉了小数(也就是在正数的地盘上向0取整了),然后再把unsigned重新强转成int,这样就又把处理好的数放回到它原来的位置上了。

题目是说是入一个整形数x,然后输出其向0取整的3/4x

#include

#include

int threefourth(int x)

{

unsigned y=3.0*x/4.0;

return y;

}

main()

{

int x;

printf("Input x:\n");

scanf("%d",&x);

int y=(int)threefourth(x);

printf("%d",y);

system("pause");

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值