
昔 Delphi で作成したものを C で書き直しました。Delphi ではまったく問題なかったのですが、C の場合、方程式の係数によって、掃き出し処理をした後 0 にマイナスが付加されることがあります。書式指定しない printf でも同じです。
なぜでしょうか?
※解は正しいです。
#include <stdio.h>
#include <math.h>
#define M 5
/* これは掃き出し処理、後単位行列になった 0 成分にマイナスがついてしまう
double A[M][M+1] = {
{ 5.0, -3.0, -3.0, 3.0, 2.0, -8.0 },
{ 9.0, -7.0, 1.0, -6.0, -5.0, -3.0 },
{ -1.0, -1.0, -8.0, 7.0, 4.0, -4.0 },
{ -7.0, 2.0, -6.0, 0.0, -1.0, -1.0 },
{ 8.0, 5.0, -3.0, 9.0, -7.0, 5.0 }
};
*/
double A[M][M+1] = { // こちらはOK
{ 2.0, 0.0, 4.0, 2.0, 0.0, 0.0 },
{ 2.0, 2.0, 0.0, 4.0, 8.0,12.0 },
{ 2.0, 4.0, 4.0, 0.0, 2.0, 0.0 },
{ 4.0, 2.0, 0.0, 0.0, 4.0, 0.0 },
{ 4.0, 0.0, 2.0, 2.0, 4.0, 8.0 }
};
//Gauss Jordan
int GaussJordan(int N)
{
double mMax, R_pivot, pivot, temp;
int pRow = -1;
for (int pv = 0; pv < N; pv++) //行ループ(一番外側のループ)
{
mMax = 0.000000001;
for (int k = pv; k < N; k++) {//行ループ ピボット行以下の最大値探索
if (abs(A[k][pv]) > mMax){
mMax = abs(A[k][pv]);
pRow = k;
}
}
if (mMax <= 0.000000001){ //0対策
printf("解が存在しないか、または不定です!");
return (0);
}
if (pv != pRow) //行の入れ替え
{
for (int k = 0; k < N + 1; k++) { //列ループ
temp = A[pv][k];
A[pv][k] = A[pRow][k];
A[pRow][k] = temp;
}
}
//ピボット行 A[pv][j] の処理
pivot = A[pv][pv];
R_pivot = 1.0 / pivot;
for (int j = 0; j < N + 1; j++) //列ループ
A[pv][j] = A[pv][j] * R_pivot; //A[pv][pv] = 1 となる
//ピボット行以外の処理 ⇒ ピボット列を 0 にする。
for (int k = 0; k < N; k++){ //行ループ
temp = A[k][pv]; //各行のピボット列成分
for (int j = pv; j < N + 1; j++) //ピボット列以降を処理
if (k != pv)
A[k][j] = A[k][j] - temp * A[pv][j];
}
}
return (1);
}
int main(void) {
printf("連立一次方程式\n");
for (int i = 0; i < M; i++) {
for (int j = 0; j < M+1; j++)
printf("%8.3g",A[i][j]);
printf("\n");
}
GaussJordan(M);
printf("\n解\n");
for (int i = 0; i < M; i++) {
for (int j = 0; j < M+1; j++)
printf("%8.3g",A[i][j]);
printf("\n");
}
}

No.2ベストアンサー
- 回答日時:
IEEE754の浮動小数点数にはゼロの正負がありますから、値として負のゼロならマイナス記号が付くのは当然のことです。
あるいは-0と表示されていても実際には-1e-10とかの小さな負の値の可能性もあります。書式指定していないときは本当に-0だと思いますけど。
-0の表示を回避したければ-0を0に置き換える処理を入れる必要があるでしょう。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# LU分解法のピボット選択機能実装について(C言語・gcc-9) 1 2022/07/22 15:20
- C言語・C++・C# 並列プログラミングのπ計算について 1 2022/07/16 22:30
- C言語・C++・C# Cのdoubleの浮動小数点表示について 3 2023/04/17 13:14
- C言語・C++・C# プログラミングの授業の課題です 1 2023/01/17 22:15
- C言語・C++・C# LU分解法のピボッティングについて(C言語/gcc-9) 3 2022/07/11 23:10
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- C言語・C++・C# C言語の課題が出たのですが自力でやっても分かりませんでした。 要素数がnであるint型の配列v2の並 3 2022/11/19 17:41
- C言語・C++・C# プログラミング c言語 4 2023/03/07 01:05
- C言語・C++・C# 10個の実数に対する降順ソート結果を出力するプログラムを作りたいのですが、以下のプログラムをどう直せ 1 2022/07/09 22:16
- C言語・C++・C# C言語のエラーについて 2 2022/07/11 13:56
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
複数桁10進数の*桁目だけを抽出...
-
C言語での引数の省略方法
-
「指定されたキャストは有効で...
-
C言語 エラーの原因がわからな...
-
if と配列の組み合わせ
-
課題でつまってます・・・
-
#define _CRT_SECURE_NO_WARNIN...
-
各桁の和を返す関数
-
構造体の勉強中です 合計点の高...
-
C言語
-
このプログラム見てください
-
「{ } で囲むだけ」は正しい?
-
ポインタを返す関数へのポインタ
-
c言語の問題です 課題1 (二分探...
-
16進数を入力とするatoi関数...
-
行列の列の絶対値の総和の最大...
-
双子の素数
-
足して100になるような乱数のア...
-
VB6でAddressOfを使った良いサ...
-
C言語でのカレンダーの表示につ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「指定されたキャストは有効で...
-
C言語での引数の省略方法
-
#define _CRT_SECURE_NO_WARNIN...
-
複数桁10進数の*桁目だけを抽出...
-
ラップ関数とはどんなものですか?
-
C言語 エラーの原因がわからな...
-
(int *)の意味
-
【C++】関数ポインタの使い方
-
if と配列の組み合わせ
-
構造体の勉強中です 合計点の高...
-
windows-findstrの正規表現を使...
-
C言語で分からないところがあり...
-
int型の変数値をバイト列として...
-
PowerShellがうまくいかない
-
C言語での奇数の和
-
「{ } で囲むだけ」は正しい?
-
std::set<int> で、ある値が何...
-
実数の整数部,小数部の取得
-
エラー 添字が付けられた値が、...
-
int16_t の _t は何?
おすすめ情報
> %.20f みたいにぎりぎりまで表示するように出力を指定すれば, どっちかは区別がつく.
やはり、マイナスがつきますね。
ま、これを表示させる必要はほとんどないのでとくに問題はないのですけど、何か引っかかる(笑)。
ちなみにC#ではこんな症状は生じませんでした。