前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >『C语言』深度走入取整 & 4种函数

『C语言』深度走入取整 & 4种函数

作者头像
謓泽
发布2022-12-12 15:58:47
5880
发布2022-12-12 15:58:47
举报
文章被收录于专栏:【C】系列

Hello🥂謓泽👋多多指教😛

🥂前言

🍻取整

⒈trunc - 0向取整

⒉floor -地板取整

⒊ceil-无穷大取整

⒋round-四舍五入

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

🍻取整 关于"取整"这个词似乎我们既熟悉又会感到陌生,熟悉是因为我们在编程的时候经常会用到取整。陌生是因为又没有好好深度理解过这取整,那么接下来就围绕取整作为一个探讨。 🍊取整⇢取整字面意思非常好理解无非就是对整数取整像2.5是一个浮点数我们对其进行取整的话就是2的整数。📝代码示例如下↓

代码语言:javascript
复制
#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 参数如下↓

代码语言:javascript
复制
     double trunc  (     double x);
      float truncf (      float x);
long double truncl (long double x);

📝代码示例如下↓

代码语言:javascript
复制
#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 参数如下↓

代码语言:javascript
复制
 double floor (double x);

📝代码示例如下↓

代码语言:javascript
复制
#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 -3  2 -3 🍊注⇢地板取整我们需要记住它是往-∞当中靠近的,从上述代码当中的运行结果相信你也可以看的出来都是往-∞当中靠近的。 ⒊ceil-无穷大取整 ceil 的头文件是 ⇢ #include<math.h> ceil 参数如下↓

代码语言:javascript
复制
 double ceil (double x);

📝代码示例如下↓

代码语言:javascript
复制
#include<stdio.h>
#include<math.h>
int main(void)
{
	printf("%2d\n", (int)ceil(2.99));
	printf("%2d\n", (int)ceil(-2.99));
	printf("%2d\n", (int)ceil(2.99));
	printf("%2d\n", (int)ceil(-2.99));
	return 0;
}

运行结果🖊  3 -2  3 -2 🍊注⇢我们需要记住它是往+∞当中靠近的,从上述代码当中的运行结果相信你也可以看的出来都是往+当中靠近的。 ⒋round-四舍五入 round 的头文件是 ⇢ #include<math.h> round 参数如下↓

代码语言:javascript
复制
     double round  (double x);
      float roundf (float x);
long double roundl (long double x);

📝代码示例如下↓

代码语言:javascript
复制
#include<stdio.h>
#include<math.h>
int main(void)
{
	printf("%2d\n", (int)round(2.99));
	printf("%2d\n", (int)round(-2.01));
	printf("%2d\n", (int)round(2.01));
	printf("%2d\n", (int)round(-2.99));
	return 0;
}

运行结果🖊  3 -3  2 -3 🍊注⇢这就是在我们数学当中的四舍五入的方式。


👌总结-最终采用哪种取决方式是根据你的应用场景来进行使用的~

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-07-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档