/**
* 数字的舍入
*
*/
public class Round
{
/**
* 利用java.lang.Math类对数字进行四舍五入
* @param dou 待舍入的数字
* @return 返回舍入后的整数
*/
public static long getTraRoundMath(double dou)
{
//Math.round方法采用首先将dou加上0.5,然后取下整数
//dou = 4.6,首先dou加0.5成5.1,其下整数为5.四舍五入的结果就是5
return Math.round(dou);
}
/**
* 对数字进行四舍五入
* @param dou 待舍入的数字
* @return 返回舍入后的整数
*/
public static long getTraRound(double dou)
{
//四舍五入模式相当于BigDecimal.ROUND_HALF_UP模式
return Round.getIntRound(dou, BigDecimal.ROUND_HALF_UP);
}
/**
* 要求舍入后返回整数类型
* @param dou 待舍入的数字
* @param roundmode 舍入模式
* @return 返回舍入后的整数
*/
public static long getIntRound(double dou,int roundmode)
{
//最后取得BigDecimal对象转化成int并返回
return Round.getRound(dou, 0, roundmode).longValue();
}
/**
* 要求舍入后返回BigDecimal类型
* @param dou 待舍入的数字
* @param scale 返回的BigDecimal对象的标度(scale)
* @param roundmode 舍入模式
* @return 返回舍入结果,一个BigDecimal对象
*/
public static BigDecimal getRound(double dou,int scale,int roundmode)
{
//创建一个新的BigDecimal对象paramNumber,该对象的值和dou大小一样
BigDecimal paramNumber = new BigDecimal(dou);
//然后调用paramNumber的setScale方法,该方法返回一个BigDecimal对象temp
//返回值的标度为第一个参数指定的值,标度为大小,表示小数部分的位数
//第二个参数指定了paramNumber对象到temp对象的舍入模式,如四舍五入等
return paramNumber.setScale(scale, roundmode);
//可以用一条语句实现:
//return new BigDecimal(dou).setScale(0,roundmode);
}
public static void main(String args[])
{
double dou1 = 8.50;
double dou2 = -9.54;
System.out.println("待舍入的数字dou1 = " + dou1 + "; dou2 = " + dou2);
System.out.println("采用Math类实现四舍五入的结果:\t" + Round.getTraRoundMath(dou1)
+ "\t" + Round.getTraRoundMath(dou2));
System.out.println("四舍五入后的结果:\t" + Round.getTraRound(dou1)
+ "\t" + Round.getTraRound(dou2));
System.out.println("要求舍入后返回整数:");
//接近正无穷大的舍入模式
System.out.println("舍入模式ROUND_CEILING:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_CEILING)
+ "\t" + Round.getIntRound(dou2, BigDecimal.ROUND_CEILING));
//接近零的舍入模式
System.out.println("舍入模式ROUND_DOWN:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_DOWN) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_DOWN));
//舍入远离零的舍入模式
System.out.println("舍入模式ROUND_UP:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_UP) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_UP));
//接近负无穷大的舍入模式
System.out.println("舍入模式ROUND_FLOOR:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_FLOOR) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_FLOOR));
//向"最接近的"数字舍入,如果与两个相邻数字的距离相等,则为ROUND_DOWN舍入模式
System.out.println("舍入模式ROUND_HALF_DOWN:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_HALF_DOWN) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_HALF_DOWN));
//向"最接近的"数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入
System.out.println("舍入模式ROUND_HALF_EVEN:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_HALF_EVEN) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_HALF_EVEN));
//向"最接近的"数字舍入,如果与两个相邻数字的距离相等,则为ROUND_UP舍入模式
System.out.println("舍入模式ROUND_HALF_UP:\t"
+ Round.getIntRound(dou1, BigDecimal.ROUND_HALF_UP) + "\t"
+ Round.getIntRound(dou2, BigDecimal.ROUND_HALF_UP));
System.out.println();
System.out.println("要求舍入后返回数字的小数部分保留一位:");
System.out.println("舍入模式ROUND_CEILING:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_CEILING)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_CEILING));
System.out.println("舍入模式ROUND_DOWN:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_DOWN)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_DOWN));
System.out.println("舍入模式ROUND_UP:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_UP)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_UP));
System.out.println("舍入模式ROUND_FLOOR:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_FLOOR)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_FLOOR));
System.out.println("舍入模式ROUND_HALF_DOWN:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_HALF_DOWN)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_HALF_DOWN));
System.out.println("舍入模式ROUND_HALF_EVEN:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_HALF_EVEN)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_HALF_EVEN));
System.out.println("舍入模式ROUND_HALF_UP:\t"
+ Round.getRound(dou1, 1,BigDecimal.ROUND_HALF_UP)
+ "\t" + Round.getRound(dou2, 1,BigDecimal.ROUND_HALF_UP));
}
}
分享到:
相关推荐
JavaScript中的数字舍入误差主要源于计算机内部以二进制表示浮点数的机制。在JavaScript中,所有数字都是以IEEE 754双精度浮点数格式存储的,这种格式有64个位来表示一个数字,其中包括1位符号位、11位指数位和52位...
银行家算法(Banker's Rounding),又称为统计学家四舍五入法或偶数舍入法,是一种常用的数字舍入方法。该方法在处理边界情况时遵循“奇进偶不进”的原则,即当保留位数后的第一位数字为5时,并且保留位数后的数字均...
在Oracle数据库中,处理数字时经常需要对数值进行各种形式的舍入操作。本文将详细介绍Oracle中的三种常见舍入方法:去尾法(Truncation)、四舍五入法(Rounding)以及收尾法(Ceiling)。这些方法对于数据处理、...
在财务计算中,我们通常希望对半舍入的数字进行上舍入,以确保总和的精确性。针对这种情况,开发者经常会编写自定义的四舍五入函数来满足这些特殊需求。 Delphi 的标准 `Format` 函数可以用于格式化字符串,其中...
四舍五入是数据处理中一种常见的舍入方法,目的是为了简化数值的表示,使之更加便于阅读和计算。在单片机和C语言编程中,由于计算精度和硬件资源的限制,正确地使用四舍五入变得尤为重要。但传统的四舍五入方法存在...
对于位数很多的近似数,当有效位数确定后,其后面多余的数字应该舍去,只保留有效数字最末一位,这种修约(舍入)规则是“四舍六入五成双”,也即“4舍6入5凑偶”,这里“四”是指≤4 时舍去,"六"是指≥6时进上,...
ROUND 函数是Excel中的一个数学函数,它可以将一个数字舍入到指定的小数位数。其语法为:`ROUND(number, num_digits)` 其中,`number`是要舍入的数字,`num_digits`是要保留的小数位数。 在我们的示例中,我们使用...
数字修约规则-----四舍五入和四舍六入五留双规则 数字修约规则是指在数字计算或测量过程中,为了简化或精确地表示数字,舍去部分数字并保留有效数字的规则。在实际应用中,数字修约规则有多种,但其中最常用的两种...
`ToString()`方法会根据这个格式化字符串将数字转换为字符串,不会执行四舍五入操作。 如果原始数字的小数位数超过3位,超出的部分会被直接截断,不会影响保留的3位小数。如果原始数字不足3位小数,后面的零会被...
### Delphi四舍五入知识点解析 #### 一、Delphi简介 Delphi 是一种基于Object Pascal语言的集成开发环境(IDE),它主要用于Windows应用程序的快速开发(RAD)。Delphi 提供了强大的可视化设计工具、丰富的类库...
- ROUND_HALF_EVEN:向最接近的数字舍入,如果与两个数字相等,则选择偶数。 - ROUND_UNNECESSARY:如果不需要舍入,则抛出异常。 在进行高精度计算时,BigDecimal 避免了浮点数计算的精度问题,提供了更精确的...
在大多数编程语言中,包括C#,`Math.Round`通常采用银行家舍入法则(Banker's Rounding),这是一种确保舍入结果在统计上更公平的方法。然而,C#的`Math.Round`行为可能会引起一些混淆,因为它的行为并不总是符合...
在Excel电子表格软件中,四舍五入是一个常见的数值处理操作,用于将数字调整到指定的小数位数。本文将详细对比三种不同的四舍五入方法:ROUND函数、MID函数配合FIND函数以及INT和*10的组合,帮助你了解它们的特点,...
Java 四舍五入方法是指在 Java 语言中对数字进行四舍五入操作的方法。四舍五入是一种常用的数字截断方法,经常用于金融、科学计算和其他领域。 在 Java 语言中,四舍五入方法可以通过多种方式实现,包括使用 Math ...
浮点数任意保留数位小数但不需四舍五入小程序
`BigDecimal`允许开发人员指定舍入模式和小数位数,从而实现更灵活的四舍五入。 #### `BigDecimal.setScale()`方法 `setScale()`方法用于设置小数点后的位数,并可以选择不同的舍入模式。其中,`BigDecimal.ROUND_...
日常接触的数据有正确数和近似数之分,不带测量误差的数均为正确数,接近但不等于某一数的数,称为该数的近似数.
在数学中,四舍五入是一种简化数字的方法,当遇到小数时,会决定保留哪些位数,以及如何处理那些不保留的位数。如果一个数位于5的下方,它会被舍去;如果它等于或高于5,那么它会被增加到最近的更高位。在编程中,...