[Java教程]一个乘法的演示程序
0 2012-07-20 01:00:05
用命令行输出手算乘法的过程,有点小意思,考察输出的formatting。可能会出现在面试中。
输入两个整数,输出格式: 两个乘数的末位数对齐 乘号后面紧跟着第二个乘数,线的长度以最长的数的位数为准,每两组测试数据中间,输出一个空行。
例如:
输入89 132 30 0
输出89 x13---- 267 89----1157 2x3-- 6
程序假设乘积在int范围内,如果大数相乘,用BigInteger处理即可。1 import java.util.*; 2 3 public class CoolMultiplication { 4 public static void main(String[] args) { 5 Scanner sc = new Scanner(System.in); 6 while (sc.hasNextLine()) { 7 int a = sc.nextInt(); 8 int b = sc.nextInt(); 9 if (a==0 || b==0) {10 System.exit(0);11 } else {12 13 int product = a * b;14 int digitOfA = getDigits(a); 15 int digitOfB = getDigits(b);16 int digitOfProduct = getDigits(product);17 int numDashes;18 if (product < 0 && b < 0) {19 numDashes = Math.max(digitOfA, Math.max(digitOfB+2,digitOfProduct+1));20 } else if (product < 0 && a < 0 ) {21 numDashes = Math.max(digitOfA+1, Math.max(digitOfB+1, digitOfProduct+1));22 } else {23 numDashes = Math.max(digitOfA, Math.max(digitOfB+1,digitOfProduct));24 }25 System.out.printf("%"+numDashes+"d\n", a);26 System.out.printf("%"+numDashes+"s\n", "x"+b);27 printDashes(numDashes);28 int[] bArr = decompose(b);29 if (bArr.length != 1) {30 for (int i=0; i
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们:admin@shaoqun.com。
0