C语言中浮点数向零舍入取整的方法
来源:互联网 发布:炒美股用什么软件 编辑:程序博客网 时间:2024/06/05 17:17
之前没想过这个问题,今天做题时碰到了,想了半天没想明白,就上网开始查,结果查了一圈也没发现什么靠谱的答案。没办法,只能在角落里慢慢硬憋出个答案了。
忽然想起来既然都是往0上靠,其实也就是正数去掉小数,负数去小数绝对值加一,于是忽然想起来C还有个unsigned可以用!欣喜若狂地试了一下,发现完美实现了向0舍入的功能!
思路就是先把double强转成unsigned,这样就把负数补到正数上去了,顺便也去掉了小数(也就是在正数的地盘上向0取整了),然后再把unsigned重新强转成int,这样就又把处理好的数放回到它原来的位置上了。
题目是说是入一个整形数x,然后输出其向0取整的3/4x
#include<stdio.h>#include<stdlib.h>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
- C语言中浮点数向零舍入取整的方法
- C语言中浮点数的比较
- c语言中浮点数的陷阱
- C语言中浮点数的运算
- C语言中浮点数的表示方法---浮点数表示引起的误差---IEEE 754关于浮点数的规定
- C语言中比较两个浮点数是否相等的方法,fabs和abs
- C语言中字符串转换浮点数的问题
- c语言中浮点数的表示形式
- c语言中浮点数的存储方式
- C语言 字符串的浮点数转换成浮点数
- C语言浮点数
- c语言浮点数
- C语言 浮点数
- C语言浮点数的二进制表示
- 【C语言】得到浮点数的二进制
- C语言 有关浮点数的总结
- C语言:浮点数的存储
- C语言中浮点型数转化为整型数的陷阱
- MySQL索引介绍
- 第一个博客
- gre vpn
- APP登陆设计 User的全局设置
- 剑指offer 31 连续子数组的最大和
- C语言中浮点数向零舍入取整的方法
- 使用Intellij IDEA 和maven创建web项目webapp全过程
- java数据解析
- SCDN博客的转载方法
- java nio 的读写操作代码示例
- 自定义画圆
- 【51Nod1967】路径定向
- hive安装问题01
- 优秀博客收藏