四类取整方式
1.C总结与剖析:关键字篇 (万字长文)2.对C语言符号的一些冷门知识运用的剖析和总结 (万字)3.位段 -- 内存布局详解-浅谈C语言4.数组降维、函数栈帧、地址空间、可变参数原理剖析 (万字)5.C语言预处理过程中语法的实用方法与技巧 (万字)6.分析负数取模与取余的规则
7.四类取整方式
8.条件编译 - 代码裁剪的工具9.理解C语言变量, auto register关键字10.循环语句与条件语句的细节与思想11.宏定义与特别运用12.浮点数与"零值"的比较13.反汇编分析赋值与自增自减14.聊聊typedef15.聊聊位运算一些注意事项16.C语言类型与强制类型转换17.标准预处理指令 可变参数 #与## 的基本用法C语言的四种取整方式:
零向取整
如图:
可以发现C语言a和b的取整方式都不是四舍五入,而是直接舍弃小数部分.(a四舍五入是-3,b四舍五入是3.)这种方式叫做零向取整.也是c语言中的默认取整方式
从图中可以看出无论是-2.9还是2.9,它们取整方向都是向着0的方向取整.
trunc函数(C99)
C语言<math.h>
库中也有零向取整函数,它的返回值是浮点型,如果需要也是可以强转成int类型使用.
trunc的使用
注意,%d不能直接接收浮点型,浮点型在内存空间中的布局和整型是不一样的,这点要注意.
如果需要转成整型使用,需要圆括号(int)
强制类型转换.
地板取整
这个名字有点奇怪,它是函数floor的翻译而来.
也叫向下取整,向左取整,向负无穷取整
floor函数的使用
向上取整
又称向右取整,向正无穷取整, 来源于ceil函数
ceil函数的使用
四舍五入
round函数(C99)
round函数的使用
四种取整方式演示
#include<stdio.h> #include<math.h> int main() { const char * format = "%.1f \t%.1f \t%.1f \t%.1f \t%.1f\n"; printf("value\tround\tfloor\tceil\ttrunc\n"); printf("-----\t-----\t-----\t----\t-----\n"); printf(format, 2.3, round(2.3), floor(2.3), ceil(2.3), trunc(2.3)); printf(format, 3.8, round(3.8), floor(3.8), ceil(3.8), trunc(3.8)); printf(format, 5.5, round(5.5), floor(5.5), ceil(5.5), trunc(5.5)); printf(format, -2.3, round(-2.3), floor(-2.3), ceil(-2.3), trunc(-2.3)); printf(format, -3.8, round(-3.8), floor(-3.8), ceil(-3.8), trunc(-3.8)); printf(format, -5.5, round(-5.5), floor(-5.5), ceil(-5.5), trunc(-5.5)); return 0; }
本文来自博客园,作者:HJfjfK,原文链接:https://www.cnblogs.com/DSCL-ing/p/18414569
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 【.NET】调用本地 Deepseek 模型
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库