Java之数组计算大数相乘


Java之数组计算大数相乘

  1. public class ArrayMulti {  
  2.     public static void main(String[] args) throws Exception {  
  3.         // TODO Auto-generated method stub   
  4.         int[] date = new int[100000];  
  5.         date[1] = 1;  
  6.         int weishu = 1// 求出来的值的位数   
  7.         System.out.println("------用数组解决大数问题---------");  
  8.         System.out.println("求n!的值");  
  9.         System.out.print("n=");  
  10.         Scanner cin = new Scanner(System.in);  
  11.         int n = cin.nextInt();  
  12.         for (int i = 1; i <= n; i++) {  
  13.             for (int j = 1; j <= weishu; j++) {  
  14.                 date[j] = date[j] * i;  
  15.             }  
  16.             // 确保除最高位外的每位不大于9   
  17.             for (int j = 1; j < weishu; j++) {  
  18.                 if (date[j] >= 10) {  
  19.                     date[j + 1] += date[j] / 10;  
  20.                     date[j] = date[j] % 10;  
  21.                 }  
  22.             }  
  23.             // 确保最高位不大于9   
  24.             while (date[weishu] >= 10) {  
  25.                 weishu++;  
  26.                 date[weishu] += date[weishu - 1] / 10;  
  27.                 date[weishu - 1] = date[weishu - 1] % 10;  
  28.             }  
  29.         }  
  30.   
  31.         System.out.print(n + "!= ");  
  32.         for (int k = weishu; k >= 1; k--) {  
  33.             System.out.print(date[k]);  
  34.         }  
  35.         System.out.println("");  
  36.     }  
  37. }

相关内容