從朋友圈一道小學試題想到的
最近在朋友圈看到一道題
使用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 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);
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 捨棄小數(即截斷)之前增加數字。