From 2da7d89123520702c38fbbcb5fee53f88ee2152a Mon Sep 17 00:00:00 2001 From: SunggyuLee Date: Wed, 19 Dec 2018 23:42:15 +0900 Subject: [PATCH] add Matrix chain multiplication algorithm --- .../MatrixChainMultiplication.java | 120 ++++++++++++++++++ 1 file changed, 120 insertions(+) create mode 100644 Dynamic Programming/MatrixChainMultiplication.java diff --git a/Dynamic Programming/MatrixChainMultiplication.java b/Dynamic Programming/MatrixChainMultiplication.java new file mode 100644 index 000000000..b22312355 --- /dev/null +++ b/Dynamic Programming/MatrixChainMultiplication.java @@ -0,0 +1,120 @@ +import java.util.ArrayList; +import java.util.Scanner; + +public class MatrixChainMultiplicationTest { + private static Scanner scan = new Scanner(System.in); + private static ArrayList mArray = new ArrayList<>(); + private static int size; + private static int[][] m; + private static int[][] s; + private static int[] p; + + public static void main(String[] args) { + int count = 1; + while(true) { + String [] mSize = input("input size of matrix A("+count+") ( ex. 10 20 ) : "); + int col = Integer.parseInt(mSize[0]); + if (col==0) break; + int row = Integer.parseInt(mSize[1]); + + Matrix matrix = new Matrix(count, col, row); + mArray.add(matrix); + count++; + } + for(Matrix m : mArray) { + System.out.format("A(%d) = %2d x %2d\n", m.count(), m.col(), m.row()); + } + + size = mArray.size(); + m = new int[size + 1][size + 1]; + s = new int[size + 1][size + 1]; + p = new int[size + 1]; + + for (int i=0; i