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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

2280閲覧

java 行列式の計算

hanao_

総合スコア6

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

1クリップ

投稿2021/12/04 09:47

Javaで行列式を計算するプログラムを書いています。

いくつかのサイトを参考にして書いてみたのですが、正しい答えが得られません、、、

Matrixクラスには二重のArrayList型である、matrixがあり、Matrixのインスタンスを生成する時に引数に指定したファイルから行列を読み込みます。(ファイルから正しく読み込むことはできています。)

det()についてですが、自分で確認してみた限りでは、

Java

1buf=m.matrix.get(j).get(i)/m.matrix.get(i).get(i);

この部分の分母が0になってしまうことで、InfinityやNaNになってしまっているということまでは確認できたのですが、これをどう修正すれば正しい計算ができるのかわかりません、、、

元の行列は

2.0 4.0 -2.0 -4.0
-6.0 -12.0 12.0 24.0
4.0 2.0 2.0 -4.0
2.0 -4.0 -2.0 4.0

で、正しい行列式の値は、1344なのですが、今のプログラムではNaNになってしまっています。

Java

1public static void main(String[] args) { 2 3 Matrix m = new Matrix(args[0]); 4 double det = 0; 5 det = m.det(); 6 System.out.println("Det: "+ det); 7 8 try { 9 BufferedWriter writer = new BufferedWriter(new FileWriter(args[1])); 10 writer.write(String.valueOf(det)); 11 writer.close(); 12 }catch(Exception e) { 13 e.printStackTrace(); 14 } 15 }

Java

1double det() { 2 //行列をコピー 3 Matrix m =new Matrix(); 4 for(int i=0;i<matrix.size();i++) { 5 ArrayList<Double> sub = new ArrayList<Double>(); 6 for(int j=0;j<matrix.get(0).size();j++) { 7 sub.add(matrix.get(i).get(j)); 8 } 9 m.matrix.add(sub); 10 } 11    //コピーが正しくされたか確認 12 m.show(); 13 14 double det=1.0; 15 double buf=0; 16 int n= m.matrix.size(); 17 18 for(int i=0;i<n;i++) { 19 for(int j=0;j<n;j++) { 20 if(i<j) { 21 buf=m.matrix.get(j).get(i)/m.matrix.get(i).get(i); 22 for(int k=0;k<n;k++) { 23 m.matrix.get(j).set(k, m.matrix.get(j).get(k)-(m.matrix.get(i).get(k)*buf)); 24 } 25 } 26 } 27 } 28 29 for(int i=0;i<n;i++) { 30 det*=m.matrix.get(i).get(i); 31 } 32 33 return det; 34 }

Java

1void show() { 2 for(int i=0;i<matrix.size();i++) { 3 for(int j=0;j<matrix.get(0).size();j++) { 4 System.out.print(" "+matrix.get(i).get(j)); 5 if(i!=matrix.size()-1) { 6 if(j==matrix.get(0).size()-1) { 7 System.out.println(); 8 } 9 } 10 } 11 if(i==matrix.size()-1) { 12 System.out.println(); 13 } 14 } 15 }

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

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

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

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

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

hoshi-takanori

2021/12/04 10:34

割り算の分母が 0 になる場合、正しい答えは存在しませんので、元の計算式が間違ってるか、データが不適切か、いずれにせよプログラム以前に何を計算したいのかを考え直す必要があるかと。
guest

回答2

0

対角行列を作ろうとする途中で、対角成分が0になります。

投稿2021/12/05 13:57

swordone

総合スコア20669

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

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

0

ベストアンサー

java

1import java.util.*; // ArrayList, Arrays, Collections 2 3class Matrix { 4 ArrayList<ArrayList<Double>> matrix; 5 6 Matrix(Double[][] d) { 7 matrix = new ArrayList<>(); 8 for (var e : d) 9 matrix.add(new ArrayList<Double>(Arrays.asList(e))); 10 } 11 12 double det() { 13 int n = matrix.size(); 14 double det = 1; 15 for (int k = 0; k < n; k++) { 16 if (matrix.get(k).get(k) == 0) 17 for (int i = k+1; i < n; i++) 18 if (matrix.get(i).get(k) != 0) { 19 Collections.swap(matrix, i, k); 20 det = -det; 21 break; 22 } 23 24 for (int i = k+1; i < n; i++) { 25 double t = matrix.get(i).get(k) / matrix.get(k).get(k); 26 for (int j = k; j < n; j++) 27 matrix.get(i).set(j, 28 matrix.get(i).get(j) - t * matrix.get(k).get(j)); 29 } 30 det *= matrix.get(k).get(k); 31 } 32 return det; 33 } 34} 35 36class Main { 37 public static void main(String[] args) { 38 Double[][] d = { 39 { 2.0, 4.0, -2.0, -4.0 }, 40 { -6.0, -12.0, 12.0, 24.0 }, 41 { 4.0, 2.0, 2.0, -4.0 }, 42 { 2.0, -4.0, -2.0, 4.0 }, 43 }; 44 Matrix m = new Matrix(d); 45 System.out.println("Det: " + m.det()); 46 } 47}

ArrayList<ArrayList<Double>> の代わりに double[][] を使えば、
もっと簡単に書けるのに、なぜそうしないのですか?

投稿2021/12/04 19:20

kazuma-s

総合スコア8224

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問