最近在朋友圈看到一道题
使用java语言写出代码如下:
package test11;
import java.math.BigDecimal;
import java.text.DecimalFormat;
public class Compute {
public static void main(String[] args) {
comput();
}
public static void comput(){
for(double a=3;a<10;a=a+0.1){
for(double b=3;b<10;b=b+0.1){
for(double c=3;c<10;c=c+0.1){
for(double d=3;d<10;d=d+0.1){
if(( Math.abs((a+b-8))<=0.001)&&( Math.abs(c-d-6)<=0.001)&&( Math.abs(a+c-13)<=0.001)&&( Math.abs(b+d-8)<=0.001)){
// System.out.println("结果完成 a= "+a+" b= "+b+" c= "+c+" d="+d);
BigDecimal a11=new BigDecimal(a);
double a1= a11.setScale(1,BigDecimal. ROUND_HALF_DOWN).doubleValue();
BigDecimal b11=new BigDecimal(b);
double b1= b11.setScale(1,BigDecimal.ROUND_HALF_DOWN).doubleValue();
BigDecimal c11=new BigDecimal(c);
double c1= c11.setScale(1,BigDecimal.ROUND_HALF_DOWN).doubleValue();
BigDecimal d11=new BigDecimal(d);
double d1= d11.setScale(1,BigDecimal.ROUND_HALF_DOWN).doubleValue();
System.out.println("结果完成 a= "+a1+" b= "+b1+" c= "+c1+" d="+d1);
break;
}
}
}
}
}
System.out.println("over");
}
}
在这里需要注意BigDecimal. ROUND_HALF_DOWN 和BigDecimal. BigDecimal. ROUND_HALF_DOWN 的区别
ROUND_HALF_UP: 遇到.5的情况时往上近似,例: 1.5 ->;2
ROUND_HALF_DOWN : 遇到.5的情况时往下近似,例: 1.5 ->;1
BigDecimal a = new BigDecimal(1.5);
System.out.println("down="+a.setScale(0,BigDecimal.ROUND_HALF_DOWN)+"/tup="+a.setScale(0,BigDecimal.ROUND_HALF_UP));
结果:down=1 up=2
看这个例子就明白了!
其他参数说明
ROUND_CEILING
如果 BigDecimal 是正的,则做 ROUND_UP 操作;如果为负,则做 ROUND_DOWN 操作。
ROUND_DOWN
从不在舍弃(即截断)的小数之前增加数字。
ROUND_FLOOR
如果 BigDecimal 为正,则作 ROUND_UP ;如果为负,则作 ROUND_DOWN 。
ROUND_HALF_DOWN
若舍弃部分> .5,则作 ROUND_UP;否则,作 ROUND_DOWN 。
ROUND_HALF_EVEN
如果舍弃部分左边的数字为奇数,则作 ROUND_HALF_UP ;如果它为偶数,则作 ROUND_HALF_DOWN 。
ROUND_HALF_UP
若舍弃部分>=.5,则作 ROUND_UP ;否则,作 ROUND_DOWN 。
ROUND_UNNECESSARY
该“伪舍入模式”实际是指明所要求的操作必须是精确的,,因此不需要舍入操作。
ROUND_UP
总是在非 0 舍弃小数(即截断)之前增加数字。