四舍五入(C语言实现)

本文介绍了两种在C语言中实现四舍五入的方法。方法一是利用取整规则,通过加0.5实现正数的四舍五入,并通过扩大和缩小数值来保留指定小数位。方法二是使用库函数`round`,需要包含`<math.h>`头文件。文章还探讨了负数四舍五入的处理,并提供了相应代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C语言中的四舍五入

我们知道,C语言直接取整是不能实现四舍五入的,我们需要靠自己的方法实现四舍五入。而且有不少题目会在浮点数的输出中要求我们四舍五入。所以学会用C语言实现四舍五入还是很有必要的。本篇文章我们介绍两种方法。

方法一:利用取整规则(不使用库函数)

先从简单的开始,比如我们现在需要将一些小数进行四舍五入并输出,比如3.5, 3.4, 3.7。请看代码:

#include <stdio.h>
int main()
{
	float arr[3] = { 3.5, 3.4, 3.7 };
	printf("将arr内容四舍五入后:\n");
	for (int i = 0; i < 3; i++)
	{
		printf("%d\n", (int)(arr[i] + 0.5));
	}
}

程序运行结果:
在这里插入图片描述

所以我们可以得到一个公式,将一位小数四舍五入的方法:(int)(浮点数+0.5);

那我们如何实现将3.1415这种浮点数进行四舍五入呢? 比如现在要求我们保留三位小数输出。
这里我们采用的方法是:先将3.1415扩大1000倍,变成3141.5,进行四舍五入后,变成3142,再缩小1000倍变成3.142。 请看代码:

#include <stdio.h>
int main()
{
	float num = 3.1415;
	num = (int)(num * 1000 + 0.5) / 1000.0;
	printf("%.3f", num);
}

程序运行结果:
在这里插入图片描述
其中特别注意的是num = (int)(num * 1000 + 0.5) / 1000.0;这里是除以1000.0,只有浮点数运算,才能使结果为浮点数。

方法二:使用库函数

C语言提供了一个四舍五入的库函数,round函数。我们去官网看看它的介绍吧!
在这里插入图片描述
我们其实只需要了解三个内容:1.库函数需要引用<math.h>头文件;2.传入参数为浮点数类型;3.返回一个整数。
就行了我们试着使用一下吧。比如我们需要将3.14159保留四位小数输出,需要四舍五入。请看代码:

#include <stdio.h>
#include <math.h>
int main()
{
	float num = 3.14159;
	num = round(num * 10000) / 10000.0;
	printf("%.4f", num);
}

程序运行结果:
在这里插入图片描述

总结

看到这里,我想你应该学会了如何用C语言实现四舍五入了吧?那我提一个小问题吧:第一种方法,如果是负数的话该如何进行四舍五入呢?可以在评论区告诉我哟。答案我会公布在动态。如果本篇博客有什么问题的话请大佬提出,我一定会积极改正!
顺便预告一下下一期的博客吧,下一期博客我会讲解一下C语言递归的一个经典问题:汉诺塔。
在这里插入图片描述

评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值