今日の人気記事

  1. while文 - 繰り返し処理
  2. 浮動小数点数型(float型 double型)の最大値と最小値 - float.h
  3. テキストファイルの読み込みと出力
  4. 文字列関数 - string.h
  5. do 〜 while文 - 繰り返し処理

3×3行列の行列式を計算する

当ページのリンクには広告が含まれています。

スポンサーリンク

3×3行列の行列式の計算するサンプルプログラムを紹介します。

行列式の計算

入力した3x3行列「A」

$$ A = \left( \begin{array}{ccc} a_{11} & a_{12} & a_{13}\\ a_{21} & a_{22} & a_{23}\\ a_{31} & a_{32} & a_{33} \end{array} \right) $$

から行列式

\begin{aligned} det A &= \left| \begin{array}{ccc} a_{11} & a_{12} & a_{13}\\ a_{21} & a_{22} & a_{23}\\ a_{31} & a_{32} & a_{33} \end{array} \right| \\ &= a_{11} \cdot det \left( \begin{array}{cc} a_{22} & a_{23}\\ a_{32} & a_{33} \end{array} \right) - a_{21} \cdot det \left( \begin{array}{cc} a_{12} & a_{13}\\ a_{32} & a_{33} \end{array} \right) + a_{31} \cdot det \left( \begin{array}{cc} a_{12} & a_{13}\\ a_{22} & a_{23} \end{array} \right) \end{aligned}

を計算します。

例えば、次の行列の行列式は

\begin{aligned} det A &= \left| \begin{array}{ccc} 1 & 5 & 3\\ 2 & 4 & 7\\ 4 & 6 & 2 \end{array} \right| \\ &= 1 \cdot det \left( \begin{array}{cc} 4 & 7\\ 6 & 2 \end{array} \right) - 2 \cdot det \left( \begin{array}{cc} 5 & 3\\ 6 & 2 \end{array} \right) + 4 \cdot det \left( \begin{array}{cc} 5 & 3\\ 4 & 7 \end{array} \right) \\ &= 1(4 \cdot 2 - 7 \cdot 6) - 2(5 \cdot 2 - 3 \cdot 6) + 4(5 \cdot 7 - 3 \cdot 4) \\ &= 1(8-42) - 2(10-18) + 4(35-12) \\ &= 1 \cdot (-34) - 2 \cdot (-8) + 4 \cdot 23 \\ &= -34 + 16 + 92 \\ &= 74 \end{aligned}

と計算できます。

サンプルプログラム

それではサンプルプログラムをみてみましょう。

/*
 * C言語のサンプルプログラム - Webkaru
 * - 3×3行列の行列式の計算 -
 */
#include <stdio.h>

int main(void){

  int i, j;

  /* 3x3 行列 */
  int a[3][3];

  /* 行列式 */
  int det = 0;

  printf("◆ 3x3の行列を入力\n");
  for(i=0;i<3;++i){
    for(j=0;j<3;++j){
      printf("A[%d][%d] = ", i+1, j+1);
      scanf("%d", &a[i][j]);
    }
  }

  /* 行列式の計算 */
  for(i=0;i<3;++i){
    det = det + a[0][i] * ( a[1][(i+1)%3] * a[2][(i+2)%3] - a[1][(i+2)%3] * a[2][(i+1)%3] );
  }

  /* 計算結果の出力 */
  printf("◆ 行列式の計算結果\n");
  printf("det A = %d\n", det);

  return 0;
}

サンプルプログラムで使っている構文

実行結果

実行結果です。

◆ 3x3の行列を入力
A[1][1] = 1
A[1][2] = 2
A[1][3] = 4
A[2][1] = 5
A[2][2] = 4
A[2][3] = 6
A[3][1] = 3
A[3][2] = 7
A[3][3] = 2
◆ 行列式の計算結果
det A = 74

このように行列式を計算・出力します。

サンプルプログラム の人気記事

  1. 入力した2つの自然数の最大公約数を求める
  2. サンプルプログラム集
  3. 配列に格納した数値を昇順ソートする
  4. ASCIIコードの表を出力する
  5. 入力した2つの数値を交換する
  6. 入力した整数が偶数か奇数かを判別する
  7. 入力した文字列をASCIIコードに変換・出力
  8. 入力した行列の積(掛け算)を計算する
  9. 九九を計算する
  10. 入力した数値が完全数かどうかを判定する

関連記事(一部広告含む)