`

数字的舍入

    博客分类:
  • J2SE
UP 
阅读更多
/**
 * 数字的舍入
 *
 */
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));
	}
}
分享到:
评论

相关推荐

    js数字舍入误差以及解决方法(必看篇)

    JavaScript中的数字舍入误差主要源于计算机内部以二进制表示浮点数的机制。在JavaScript中,所有数字都是以IEEE 754双精度浮点数格式存储的,这种格式有64个位来表示一个数字,其中包括1位符号位、11位指数位和52位...

    Delphi 四舍五入

    银行家算法(Banker's Rounding),又称为统计学家四舍五入法或偶数舍入法,是一种常用的数字舍入方法。该方法在处理边界情况时遵循“奇进偶不进”的原则,即当保留位数后的第一位数字为5时,并且保留位数后的数字均...

    oracle数字的四舍五入、去尾、收尾法

    在Oracle数据库中,处理数字时经常需要对数值进行各种形式的舍入操作。本文将详细介绍Oracle中的三种常见舍入方法:去尾法(Truncation)、四舍五入法(Rounding)以及收尾法(Ceiling)。这些方法对于数据处理、...

    Delphi 自已写的四舍五入函数

    在财务计算中,我们通常希望对半舍入的数字进行上舍入,以确保总和的精确性。针对这种情况,开发者经常会编写自定义的四舍五入函数来满足这些特殊需求。 Delphi 的标准 `Format` 函数可以用于格式化字符串,其中...

    四舍五入?四舍六入!

    四舍五入是数据处理中一种常见的舍入方法,目的是为了简化数值的表示,使之更加便于阅读和计算。在单片机和C语言编程中,由于计算精度和硬件资源的限制,正确地使用四舍五入变得尤为重要。但传统的四舍五入方法存在...

    一秒把excel表格中的数字变成中文大写数字金额.doc

    ROUND 函数是Excel中的一个数学函数,它可以将一个数字舍入到指定的小数位数。其语法为:`ROUND(number, num_digits)` 其中,`number`是要舍入的数字,`num_digits`是要保留的小数位数。 在我们的示例中,我们使用...

    sqlserver四舍六入函数

    对于位数很多的近似数,当有效位数确定后,其后面多余的数字应该舍去,只保留有效数字最末一位,这种修约(舍入)规则是“四舍六入五成双”,也即“4舍6入5凑偶”,这里“四”是指≤4 时舍去,"六"是指≥6时进上,...

    数字修约规则-----四舍五入和四舍六入五留双规则[文].pdf

    数字修约规则-----四舍五入和四舍六入五留双规则 数字修约规则是指在数字计算或测量过程中,为了简化或精确地表示数字,舍去部分数字并保留有效数字的规则。在实际应用中,数字修约规则有多种,但其中最常用的两种...

    C# 截取小数,不四舍五入

    `ToString()`方法会根据这个格式化字符串将数字转换为字符串,不会执行四舍五入操作。 如果原始数字的小数位数超过3位,超出的部分会被直接截断,不会影响保留的3位小数。如果原始数字不足3位小数,后面的零会被...

    Delphi四舍五入

    ### Delphi四舍五入知识点解析 #### 一、Delphi简介 Delphi 是一种基于Object Pascal语言的集成开发环境(IDE),它主要用于Windows应用程序的快速开发(RAD)。Delphi 提供了强大的可视化设计工具、丰富的类库...

    BigDecimal加减乘除计算

    - ROUND_HALF_EVEN:向最接近的数字舍入,如果与两个数字相等,则选择偶数。 - ROUND_UNNECESSARY:如果不需要舍入,则抛出异常。 在进行高精度计算时,BigDecimal 避免了浮点数计算的精度问题,提供了更精确的...

    C#使用round函数四舍五入的方法

    在大多数编程语言中,包括C#,`Math.Round`通常采用银行家舍入法则(Banker's Rounding),这是一种确保舍入结果在统计上更公平的方法。然而,C#的`Math.Round`行为可能会引起一些混淆,因为它的行为并不总是符合...

    excel中四舍五入的三种方法的比较

    在Excel电子表格软件中,四舍五入是一个常见的数值处理操作,用于将数字调整到指定的小数位数。本文将详细对比三种不同的四舍五入方法:ROUND函数、MID函数配合FIND函数以及INT和*10的组合,帮助你了解它们的特点,...

    java四舍五入

    Java 四舍五入方法是指在 Java 语言中对数字进行四舍五入操作的方法。四舍五入是一种常用的数字截断方法,经常用于金融、科学计算和其他领域。 在 Java 语言中,四舍五入方法可以通过多种方式实现,包括使用 Math ...

    java 数字格式化程序(不需四舍五入)

    浮点数任意保留数位小数但不需四舍五入小程序

    java 四舍五入 需要的朋友看看

    `BigDecimal`允许开发人员指定舍入模式和小数位数,从而实现更灵活的四舍五入。 #### `BigDecimal.setScale()`方法 `setScale()`方法用于设置小数点后的位数,并可以选择不同的舍入模式。其中,`BigDecimal.ROUND_...

    有效数字和数据舍入规则.ppt

    日常接触的数据有正确数和近似数之分,不带测量误差的数均为正确数,接近但不等于某一数的数,称为该数的近似数.

    四舍五入_四舍五入问题_源码

    在数学中,四舍五入是一种简化数字的方法,当遇到小数时,会决定保留哪些位数,以及如何处理那些不保留的位数。如果一个数位于5的下方,它会被舍去;如果它等于或高于5,那么它会被增加到最近的更高位。在编程中,...

Global site tag (gtag.js) - Google Analytics