質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

Q&A

解決済

2回答

1361閲覧

【C言語】3次の行列の行列式が求められません

Tora3

総合スコア2

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

0グッド

0クリップ

投稿2022/01/07 16:01

編集2022/01/08 02:07

前提・実現したいこと

C言語です。
3×3実行列の行列式を求めたいのですがうまくいきません。
ご教授お願い致します。

発生している問題・エラーメッセージ

diagonalization1-1.c: In function ‘main’: diagonalization1-1.c:8:5: error: pointer value used where a floating point value was expected 8 | A[3][3] = (double )malloc(i*k*sizeof(double)); | ^

該当のソースコード

C言語

1#include <stdio.h> 2#include<stdlib.h> 3 4int main(void) { 5 6 int i, j, k; 7 double A[3][3]; 8 A[3][3] = (double )malloc(i*k*sizeof(double)); 9 for (i = 0; i < 3; i++) { 10 for (j = 0; j < 3; j++) { 11 printf("A[%d][%d]=", i, j); 12 scanf("%lf", &A[i][j]); 13 } 14 } 15 16 double determinant; 17 18 determinant = A[0][0] * A[1][1] * A[2][2] + A[0][1] * A[1][2] * A[2][0] + A[0][2] * A[1][0] * A[2][1] - A[0][0] * A[1][2] * A[2][1] - A[0][1] * A[1][0] * A[2][2] - A[0][2] * A[1][1] * A[2][0]; 19 20 printf("determinant:%f\n", determinant); 21 22 return 0; 23} 24

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kazuma-s

2022/01/07 17:09

> 3×3実行列の行列式を求めたいのですがうまくいきません。 うまくいかない場合の入力データは何ですか? 質問に追記してください。
Tora3

2022/01/08 02:08

回答していただきありがとうございます。 現在scanfに入力ができない状態となっております。 よろしくお願いいたします。
guest

回答2

0

diff

1- scanf("%lf", A[i*3+j]); 2+ scanf("%lf", &A[i][j]); 3 4- int determinant; 5+ double determinant; 6 7- printf("determinant:%d\n", determinant); 8+ printf("determinant:%g\n", determinant);

投稿2022/01/07 16:33

編集2022/01/07 17:11
kazuma-s

総合スコア8224

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

× scanf("%lf", A[i*3+j]);
○ scanf("%lf", &A[i][j]);

[追記] それともやりたかったのはコレ↓か?

C

1#include <stdio.h> 2#include <stdlib.h> 3 4int main(void) { 5 6 int i, j; 7 i = 3; j = 3; k = 3; 8 double* A = (double*)malloc(i*k*sizeof(double)); 9 for (i = 0; i < 3; i++) { 10 for (j = 0; j < 3; j++) { 11 printf("A[%d][%d]=", i, j); 12 scanf("%lf", &A[i*k+j]); 13 } 14 } 15 16 double determinant; 17 18 determinant = A[0*k+0] * A[1*k+1] * A[2*k+2] 19 + A[0*k+1] * A[1*k+2] * A[2*k+0] 20 + A[0*k+2] * A[1*k+0] * A[2*k+1] 21 - A[0*k+0] * A[1*k+2] * A[2*k+1] 22 - A[0*k+1] * A[1*k+0] * A[2*k+2] 23 - A[0*k+2] * A[1*k+1] * A[2*k+0]; 24 25 printf("determinant:%f\n", determinant); 26 free(A); 27 return 0; 28}

投稿2022/01/07 16:22

編集2022/01/08 06:14
episteme

総合スコア16612

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Tora3

2022/01/08 02:08

記載の通り、編集しました。 まだエラーが出てしまうですが、教えていただけると助かります。
kazuma-s

2022/01/08 03:14

記載の通りの編集ではありませんよね。 なぜ、A[3][3] = (double )malloc(i*k*sizeof(double)); を追加したのですか? i や k の値はいくつですか? malloc は領域を確保しその先頭アドレスをポインタとして返しますが、 なぜ、そのポインタを double に型変換しようとするのですか? A[3][3] は配列の範囲外です。A[0][0]~A[2][2] しかアクセスできません。
episteme

2022/01/08 04:02

ゴールポストを動かしたんやね...
Tora3

2022/01/08 10:40

ありがとうございます。 無事にコンパイルが通りました。 計算結果も正しいものになりました。
episteme

2022/01/08 11:17

kazuma-s の問いに答えていません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問