四舍五入浮点数

2023-12-17 15:49:19

1.题目如下:?

?2.方法一:

直接取出小数部分第一位来判断。

1. 先乘以10。

2. 强制类型转换为整型,去掉小数部分。

3. 再模10,相当于取出原数的小数第一位。

代码实现:

int way1(double n)
{
	int a = (int)(n * 10);
	int b = a % 10;//取出小数第一位
	if (b >= 0)//正数
	{
		if (b >= 0 && b < 5)
		{
			return (int)n;
		}
		else
		{
			return (int)(n + 1);
		}
	}
	else//负数
	{
		if (b <= -1 && b > -5)
		{
			return (int)n;
		}
		else
		{
			return (int)(n - 1);
		}
	}
}

贝蒂说:“要注意考虑负数的情况哦~”?

3.方法二:

?利用库函数round()

1. 头文件<math.h>

2. 声明:double round(double x)

3. 作用:用于四舍五入浮点数到最接近的整数值。

?代码如下:

#include<math.h>
int way2(double n)
{
	return (int)round(n);
}

4. 方法三:

直接法

1. 如果n是正数,直接将n+0.5,再强制类型转换为int返回。

2. 如果n是负数,直接将n-0.5,再强制类型转换为int返回。

int way3(double n)
{
	if (n >= 0)
	{
		return (int)(n + 0.5);
	}
	else
	{
		return (int)(n - 0.5);
	}
}

?贝蒂说:“这种方法需要我们理解到,强制类型转换为int,会把小数部分直接去掉哦~”

文章来源:https://blog.csdn.net/Bettysweetyaaa/article/details/135044488
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。