「Gauss-Jordan消去法」を使って、プログラムは入力部分、計算部分、出力部分に分けメイン関数から呼び出すようにしするプログラムを作る。以下のプログラムの間違ったところを直して以下だけますか。
#include<stdio.h>
#define N 100
void output(int n, int s, double a[][N], double b[]) {
int i, j;
printf("\n第%2d 消去ステップ\n", s);
for (i = 1; i <= n; i++) {
for (j = 1; j <= n; j++)
printf(" %8.2f", a[i][j]);
printf(" %8.2f\n", b[i]);
}
}
void data_in(int *n, double *a[N][N], double *b[N]) {
int i, j;
printf("namber of demension(n) = ");
scanf("%d", &n);
for (i = 1; i <= *n; i++) {
for (j = 1; j <= *n; j++) {
printf("a[%d][%d] =", i, j);
scanf("%lf", &a[i][j]);
}
printf("b[%d] =", i);
scanf("%lf", &b[i]);
}
}
void calcution(int n, double a[N][N], double b[N], double *x[N]) {
int i, j, k;
double q, p;
printf("\nGauss-Jordan消去法\n");
printf("input data\n");
for (j = 1; j <= n; j++)
printf(" x%d", j);
printf(" rhs\n");
for (i = 1; i <= n; i++) {
for (j = 1; j <= n; j++)
printf(" %7.2f", a[i][j]);
printf(" %7.2f\n", b[i]);
}
for (i = 1; i <= n; i++) {
p = a[i][i];
for (j = i; j <= n; j++) a[i][j] = a[i][j] / p;
b[i] = b[i] / p;
for (k = 1; k <= n; k++) {
if (k != i) {
q = a[k][i];
for (j = i; j <= n; j++)
a[k][j] -= q*a[i][j];
b[k] -= q*b[i];
}
}
output(n, i, a, b);
}
*x[N] = b[i];
}
void data_out(int n, double x[N]) {
int i;
printf("\nsolution :\n\n");
for (i = 1; i <= n; i++)
printf(" x[%d] = %8.2f\n", i, x[i]);
}
int main(void) {
int n, s;
double a[N][N], b[N], x[N];
output(n, s, a, b);
data_in(&n, &a, &b);
calcution(n, a, b[N], &x[N]);
data_out(n, &x[N]);
return 0;
}
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
そもそも、他人にデバッグやってもらおう、ってのがおかしいんですよね。
コンパイルが失敗したら、コンパイラがエラーの原因を伝えてくれる筈なんですが。
そして、ソースにコメントが無いんで何をやろうとしてるんだかサッパリ分からない。
例えば、main関数内で整数
int n, s
が定義されていますが、一体こいつらが何の為に存在してるのか分からない。
分からないんだけど、いきなりoutput関数の引数として渡されて「実体が無いままに」output関数のステップ数表示に使われたりforループを制御しようとする。一体いつ、nやsの「具体的な数」が与えられたんだろう?
とまぁ、このように、各関数内の「実装目的」とか、各引数の「存在目的」とか、他人が読んでもサッパリ分からんのですよね。一体何がしたいのか。
と言うわけで、少なくとも「コメントを付ける」習慣を付けましょう。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# 10個の実数に対する降順ソート結果を出力するプログラムを作りたいのですが、以下のプログラムをどう直せ 1 2022/07/09 22:16
- C言語・C++・C# c言語でユーザ関数を利用して複素数のべき乗と絶対値の数列を計算するプログラムが作りたいです。 3 2023/01/29 22:13
- C言語・C++・C# C 言語の Gauss Jordan 法について 2 2022/12/28 11:16
- C言語・C++・C# Cのdoubleの浮動小数点表示について 3 2023/04/17 13:14
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# 並列プログラミングのπ計算について 1 2022/07/16 22:30
- C言語・C++・C# LU分解法のピボッティングについて(C言語/gcc-9) 3 2022/07/11 23:10
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
- C言語・C++・C# C言語(構造体) 3 2022/07/05 20:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
printf で二進表示を行いたい。
-
10個出力で改行したいのですが...
-
コマンドラインに出力した文字...
-
ブラックジャック
-
C言語で、「自然数nを入力し、n...
-
error C2143: 構文エラー : ';'...
-
scanfに文字が入力されたときに...
-
4の倍数を論理演算で表す。。
-
縦の棒グラフ
-
パスカルの三角形についてのCプ...
-
(C言語)めちゃくちゃな値にな...
-
ピラミッド表示プログラム。
-
C言語 ツェラーの公式を使った...
-
CTRL+Dでループを抜けるには
-
勝率をプログラムに
-
Visual Sutdio 2017 でのC言語...
-
%P と %X の違い
-
printf( " %2d", p * q );
-
C言語 プログラミング ごめんな...
-
printf()文の書式
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
10個出力で改行したいのですが...
-
既約分数の表示プログラム
-
printf で二進表示を行いたい。
-
8人分のテストの点数を入力し、...
-
printf( " %2d", p * q );
-
strcmp
-
CTRL+Dでループを抜けるには
-
4の倍数を論理演算で表す。。
-
%P と %X の違い
-
【C言語教えてください】sin波...
-
c言語でAからZまでを表示する...
-
cshの文字列操作(0埋め)
-
万年カレンダーのC言語プログラ...
-
コマンドラインに出力した文字...
-
scanfに文字が入力されたときに...
-
コンパイルエラーについて
-
ホームページをC言語で作りたい...
-
改行について 1行に何個かづ...
-
台形の面積を求めるプログラム
-
なぜgccはstdio.hをインクルー...
おすすめ情報