Problem 1856 The Troop
Accept: 72 Submit: 245Time Limit: 1000 mSec Memory Limit : 32768 KB
Problem Description
The troop is advancing. The length of the queue is x meter. The commander is at the front of the queue, riding his horse. The crier is at the end of the queue. If something happen, the crier should talk to the commander. Now, the crier run to the commander. Then run back. We know the troop has advanced x meter. So what is the number of meter the crier run. You can assume the speed of the crier is bigger than the troop.
Input
There are multiple test case, in every case, there will be a real number x. which means the distance the troop advances. 0 < x < 10^1000
Output
For each test case you should print the answer. Use the print format as below. Print a blank line after each case. Because of the Accuracy error, If answer >= 100000,you should just output the front five digit. Else round to the four digits after the decimal point.
Sample Input
100 100000
Sample Output
Case 1 241.4214 Case 2 24142
思路:直接根据样例看出这是1+根号2.
收获:JAVA 对象,类, 构造函数。
import java.math.*;import java.util.*;public class Main { public static void main(String[] args) { // TODO Auto-generated method stub Scanner in = new Scanner(System.in); BigDecimal x, cell = BigDecimal.ONE; cell = cell.add(new BigDecimal(Math.sqrt(2.0))); String str; int t = 1; while(in.hasNext()) { x = in.nextBigDecimal(); x = x.multiply(cell); str = x.toString(); System.out.println("Case "+ t); t++; if(x.compareTo(BigDecimal.valueOf(100000.0)) >= 0) System.out.println(str.substring(0, 5)); else{ x = x.divide(BigDecimal.ONE, 4, RoundingMode.HALF_UP); System.out.println(x); } System.out.println(); } }}