hdu 3546(高精度,java写)...
时间:2010-08-18 来源:xiaotaoqibao
Calculator
Time Limit: 2000/2000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others)
Total Submission(s): 173 Accepted Submission(s): 65
1) Assignment: X=Y
2) Addition: X+=Y
3) Multiplication: X*=Y
Notice that X and Y are two registers, and they may be the same.
Initially, all the registers are stored by integer 1. Your program should operate several operations and output the final result for 10 registers. You may assume that the length of each decimal number stored in the register is no longer than 5000. Input The input contains only one test case including several lines.
Each line contains an operation to be calculated.
The number of operations will no more than 300000. Output The output should contains exactly 10 lines, each line contains an integer denoting the decimal number in the register. See sample test case for further details. Sample Input
A+=B A*=A A+=A B+=A C+=B D=BSample Output
8 9 10 9 1 1 1 1 1 1import java.io.*; import java.util.*; import java.math.*; public class Main { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub Scanner cin=new Scanner(System.in); BigInteger elem[] = new BigInteger[10]; String str; int i,j; for(i=0;i<10;i++) elem[i] = BigInteger.ONE; while(cin.hasNext()){ str = cin.next(); if(str.length()==3) { elem[str.charAt(0)-'A'] = elem[str.charAt(2)-'A']; } else { if(str.charAt(1) == '+') elem[str.charAt(0)-'A'] = elem[str.charAt(0)-'A'].add(elem[str.charAt(3)-'A']); else elem[str.charAt(0)-'A'] = elem[str.charAt(0)-'A'].multiply(elem[str.charAt(3)-'A']); } } for(i=0;i<10;i++) { System.out.println(elem[i]); } } }
相关阅读 更多 +