四舍五入(C语言实现)
我们知道,C语言直接取整是不能实现四舍五入的,我们需要靠自己的方法实现四舍五入。而且有不少题目会在浮点数的输出中要求我们四舍五入。所以学会用C语言实现四舍五入还是很有必要的。本篇文章我们介绍两种方法。...
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语言递归的一个经典问题:汉诺塔。
更多推荐
所有评论(0)