雨谷の日和

過去20年で2,800を超えるアニメの第1話だけは見続けた僕のお勧めアニメがハズレなはずがない

Javaでの行列式計算(再帰無し、事前)

では改めて。
2004.05.15付のソースコードを、今度は事前メモリ確保のそれに書き換えてみよう。

  private static long array_buf;

  public static long expand01(long array) {
    return array[0];
  }

(省略)

  public static long expand11(long array) {
    int i, j, k, l;
    long value = 0;
    long[] subarray = array_buf[9];
    for(i = 0; i < 11; ++i) {
      l = 0;
      for(j = 0; j < 11; ++j){
        if(j != i){
          for(k = 1; k < 11; ++k)subarray[(l * 10) + k - 1] = array[(j * 11) + k];
          ++l;
        }
      }
      if(i % 2 == 0){
        value += (array[i * 11] * expand10(subarray));
      }else{
        value -= (array[i * 11] * expand10(subarray));
      }
    }
    return value;
  }

  public static void main(String[ ] args) throws Exception {
    long[ ] array = new long[ ]{
      1, 2, 3, 4, 6, 1, 7, 1, 9, 0, 0, 
      5, 1, 5, 7, 7, 3, 5, 3, 6, 1, 6, 
      7, 6, 4, 8, 4, 6, 1, 7, 1, 4, 8, 
      6, 5, 1, 0, 1, 5, 9, 1, 7, 5, 1, 
      2, 3, 1, 1, 5, 8, 4, 6, 3, 1, 5, 
      3, 1, 0, 3, 2, 9, 4, 8, 0, 3, 1, 
      3, 2, 8, 5, 0, 6, 3, 4, 4, 8, 5, 
      4, 9, 9, 4, 6, 1, 0, 1, 2, 1, 6, 
      9, 7, 6, 1, 6, 4, 5, 2, 9, 4, 4, 
      1, 2, 2, 2, 8, 3, 4, 9, 1, 2, 4, 
      6, 1, 6, 4, 4, 8, 6, 3, 4, 1, 4, 
    };
    array_buf = new long[10][11 * 11];
    long value = expand11(array);
    System.out.println("result: " + value);
  }

次回は、これを実行した時のprofileを見てみる。