1 2 -1
D= 3 0 -2
-1 1 2
の3次正方行列のn乗を計算するプログラムを作成しています。
いろいろと試してみましたがうまくいきません。
どなたか教えていただけるとうれしいです。
よろしくおねがいします。
#include <stdio.h>
int main(void)
{
int a[3][3]={ {-1,2,-1},{3,0,-2},{-1,1,2} };
int b[3][3]={ {-1,2,-1},{3,0,-2},{-1,1,2} };
int s[3][3];
int m,n;
int i,j,k;
printf("[A]^n;n = ");scanf("%d",&n);
for (m=2;m <= n;m++){
for (i=0;i<3;i++){
for (j=0;j<3;j++){
s[i][j] = 0;
for(k=0;k<3;k++){
s[i][j] =s[i][j] + a[i][k] * b[k][j];
}
}
}
for(i=0;i<3;i++){
for(j=0;j<3;j++){
b[i][j]=s[i][j];
}
}
printf("%3d",s[i][j]);
putchar('\n');
}
return (0);
}
No.2ベストアンサー
- 回答日時:
計算方法はあってます。
違っているのは次の2箇所です。
(1) 行列a, bの値設定
(2) 計算結果の表示
> int a[3][3]={ {-1,2,-1},{3,0,-2},{-1,1,2} };
> int b[3][3]={ {-1,2,-1},{3,0,-2},{-1,1,2} };
1行1列目の要素(つまりa[0][0]とb[0][0]の値)が-1になっています。
行列Dの1行1列目の要素は1ですよね。
> printf("%3d",s[i][j]);
> putchar('\n');
この2行だけだとs[3][3]だけを表示して終わってしまいます。
また、この位置で出力してしまうと2乗 ~ n乗の結果が全部表示されてしまいます。
n乗の結果のみを出力したいなら、
この2行を消してreturn文の直前に
for(i = 0; i < 3; i++){
for(j = 0; j < 3; j++){
printf("%3d",s[i][j]);
}
putchar('\n');
}
と打ち込んでみましょう
(ちなみに上のコードは全角空白を含んでいるので、
回答文からこのコードをコピー&ペーストしてしまうと
コンパイルエラーが起きるので注意してください)。
No.4
- 回答日時:
printf("%3d",s[i][j]);
ここ,上の i,j の for 文抜けた後だから,
i=3, j=3 の s[3][3] つまり,
行列の 4,4 成分を表示している.
コンパイルエラーか segmentation faults か意味のない数を表示するか
のどれか
printf("%3d",s[i][j]);
putchar('\n');
の2行を
for(i=0;i<3;i++){
for(j=0;j<3;j++){
printf("%3d",s[i][j]);
}
putchar('\n');
}
に置き換える.
No.3
- 回答日時:
カテゴリー違いです。
そのプログラムでは、n が 2 以上であれば、
return の直前の時点で、s[][] の中に
a[][] の n 乗が正しく求められています。
デバッガ上で s の値を確認すれば判ことです。
表示が上手くいかないとすれば、
数学以外の点に誤りがあります。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
マイナスからプラスへ転じた時...
-
エクセルで可視セルにのみ値貼...
-
ある商品のロス率を5%見込み、...
-
20'(角度)の計算がわかりま...
-
2÷3などの余りについて
-
信頼区間の1.96や1.65ってどこ...
-
Aの値からBの値を除するとは??
-
エクセルのオートフィル?ドラ...
-
変数とパラメータとは違うもの...
-
比と比の値について。 a:b=a/b ...
-
「Aに対するBの割合」と「Aに対...
-
楕円の外周の計算方法
-
値差の%計算方法について
-
大学数学の問題です。 加法群Z/...
-
今年の一橋大学の整数問題の第...
-
シグマを平均値で割る
-
三角分布に従う乱数
-
Wavelet解析におけるGaborのマ...
-
正弦定理と余弦定理で答が違う?
-
一次関数についてです。 y=5な...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
信頼区間の1.96や1.65ってどこ...
-
2÷3などの余りについて
-
マイナスからプラスへ転じた時...
-
「Aに対するBの割合」と「Aに対...
-
Aの値からBの値を除するとは??
-
EXCELの分散分析表のP-値が....
-
変数とパラメータとは違うもの...
-
ある商品のロス率を5%見込み、...
-
エクセルで可視セルにのみ値貼...
-
20'(角度)の計算がわかりま...
-
大学数学の問題です。 加法群Z/...
-
独立係数について教えて下さい。
-
値差の%計算方法について
-
数学(数列)の問題です。ーど...
-
教えてください。数学Bの二項分...
-
Excelで1つしかない値だけを抽...
-
数学 数直線の見方
-
中学生で数学です。 √84nが自然...
-
楕円の外周の計算方法
-
10%引いた元の数字を出すには?
おすすめ情報