【C语言】trunc、floor。

时间:2021-07-14 00:38:33

????write in front????   

????大家好,我是謓泽,希望你看完之后,能对你有所帮助,不足请指正!共同学习交流????

????2021|2022年度博客之星物联网与嵌入式开发TOP5|TOP4~2021博客之星TOP100~2022博客之星TOP63~作者周榜84﹣作者总榜704~阿里云专家博主 & 阿里云星级博主~掘金优秀创作者⇿InfoQ创作者⇿51CTO红人⇿全网访问量50w+????

????本文由 謓泽 原创 如需转载还请通知⚠

????个人主页-​謓泽51Ctop的博客​????

????欢迎各位→点赞???? + 收藏⭐️ + 留言????

????系列专栏-​謓泽51Ctop的博客_【C语言】从0~1_51CTO博客​????
✉️我们并非登上我们所选择的舞台,演出并非我们所选择的剧本????

????前言

这篇博客就带大家深度理解以下什么是取整。我提到的"深度"就可以看出来这篇文章对取整讲解的还是很详细的并且是肯定有些知识点内容在里面的,但是不要觉得深度就是设计到很多很困难的知识点。实际上都是一些相对且容易的一些知识点,那么废话不多说进入正题????

【C语言】trunc、floor。

????取整

关于"取整"这个词似乎我们既熟悉又会感到陌生,熟悉是因为我们在编程的时候经常会用到取整。陌生是因为又没有好好深度理解过这取整,那么接下来就围绕取整作为一个探讨。

????取整⇢取整字面意思非常好理解无非就是对整数取整像2.5是一个浮点数我们对其进行取整的话就是2的整数。????代码示例如下↓

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main(void)
{
int a = 2.99;
int b = -2.99;
printf("a=%2d\n", a);
printf("b=%2d\n", b);
return 0;
}

运行结果????

a =  2

b = -2

????说明⇢在上述代码当中我们可以知道并不是按照我们数学意义上的四舍五入而是不管你的小数位多大都的取整,这也是为什么我变量小数点取怎么大的原因也就是想让大家能非常直观的理解这个概念。一句话:直接把小数点后面的数字给省略了。

????总结⇢「C语言」取整默认采用的是"0向取整"

⒈trunc - 0向取整

trunc 的头文件是 ⇢ #include<math.h>

????拓展知识点⇢对于「C语言」来说它实际上是有一个取整函数的相信很多小伙伴们是不知道「C语言」有这个trunc取整函数的。

trunc 参数如下↓

double trunc  (     double x);
float truncf ( float x);
long double truncl (long double x);

????代码示例如下↓

#include<stdio.h>
#include<math.h>
int main(void)
{
printf("%2f\n", trunc(2.99));
printf("%2f\n", trunc(-2.99));
printf("%2d\n", (int)trunc(2.99));
printf("%2d\n", (int)trunc(-2.99));
return 0;
}

运行结果????

 2

-2

 2

-2

????注⇢这里我们需要注意函数的返回值都是浮点类型,如果你是用整形打印的话你需要把类型进行强转成(int)

????说明⇢在C语言当中默认采用的是0向取整的方式来进行的。

⒉floor -地板取整

floor 的头文件是 ⇢ #include<math.h>

floor 参数如下↓

double floor (double x);

????代码示例如下↓

#include<stdio.h>
#include<math.h>
int main(void)
{
printf("%2d\n", (int)floor(2.99));
printf("%2d\n", (int)floor(-2.99));
printf("%2d\n", (int)floor(2.99));
printf("%2d\n", (int)floor(-2.99));
return 0;
}

运行结果????

 2

-3

 2

-3

????注⇢地板取整我们需要记住它是往-∞当中靠近的,从上述代码当中的运行结果相信你也可以看的出来都是往-∞当中靠近的,反之。