This is a java program to perform optimal paranthesization by making use of dymanic programming. This program determines the order in which the chain of matrices should be multiplied.
Here is the source code of the Java Program to Perform Optimal Paranthesization Using Dynamic Programming. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.sanfoundry.numerical; import java.util.Scanner; public class OptimalParanthesizationUsingDP { private int[][] m; private int[][] s; private int n; public OptimalParanthesizationUsingDP(int[] p) { n = p.length - 1; // how many matrices are in the chain m = new int[n + 1][n + 1]; // overallocate m, so that we don't use index // 0 s = new int[n + 1][n + 1]; // same for s matrixChainOrder(p); // run the dynamic-programming algorithm } private void matrixChainOrder(int[] p) { // Initial the cost for the empty subproblems. for (int i = 1; i <= n; i++) m[i][i] = 0; // Solve for chains of increasing length l. for (int l = 2; l <= n; l++) { for (int i = 1; i <= n - l + 1; i++) { int j = i + l - 1; m[i][j] = Integer.MAX_VALUE; // Check each possible split to see if it's better // than all seen so far. for (int k = i; k < j; k++) { int q = m[i][k] + m[k + 1][j] + p[i - 1] * p[k] * p[j]; if (q < m[i][j]) { // q is the best split for this subproblem so far. m[i][j] = q; s[i][j] = k; } } } } } private String printOptimalParens(int i, int j) { if (i == j) return "A[" + i + "]"; else return "(" + printOptimalParens(i, s[i][j]) + printOptimalParens(s[i][j] + 1, j) + ")"; } public String toString() { return printOptimalParens(1, n); } public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out .println("Enter the array p[], which represents the chain of matrices such that the ith matrix Ai is of dimension p[i-1] x p[i]"); System.out.println("Enter the total length: "); int n = sc.nextInt(); int arr[] = new int[n]; System.out.println("Enter the dimensions: "); for (int i = 0; i < n; i++) arr[i] = sc.nextInt(); OptimalParanthesizationUsingDP opudp = new OptimalParanthesizationUsingDP( arr); System.out.println("Matrices are of order: "); for (int i = 1; i < arr.length; i++) { System.out.println("A" + i + "-->" + arr[i - 1] + "x" + arr[i]); } System.out.println(opudp.toString()); sc.close(); } }
Output:
$ javac OptimalParanthesizationUsingDP.java $ java OptimalParanthesizationUsingDP Enter the array p[], which represents the chain of matrices such that the ith matrix Ai is of dimension p[i-1] x p[i] Enter the total length: 5 Enter the dimensions: 2 4 5 2 1 Matrices are of order: A1-->2x4 A2-->4x5 A3-->5x2 A4-->2x1 (A[1](A[2](A[3]A[4])))
Related posts:
Java Program to find the number of occurrences of a given number using Binary Search approach
Apache Camel with Spring Boot
Spring Boot Configuration with Jasypt
Recommended Package Structure of a Spring Boot Project
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
Java Program to Find kth Smallest Element by the Method of Partitioning the Array
Java Program to Implement Caesar Cypher
Spring WebClient Filters
Java Program to Implement Sorted Singly Linked List
Spring MVC Tutorial
Java Program to Create a Random Graph Using Random Edge Generation
Using a Spring Cloud App Starter
A Quick JUnit vs TestNG Comparison
Java Program to Check Multiplicability of Two Matrices
Xử lý ngoại lệ đối với trường hợp ghi đè phương thức trong java
Returning Image/Media Data with Spring MVC
Default Password Encoder in Spring Security 5
Introduction to Netflix Archaius with Spring Cloud
Toán tử instanceof trong java
Serialize Only Fields that meet a Custom Criteria with Jackson
Rest Web service: Filter và Interceptor với Jersey 2.x (P1)
Câu lệnh điều khiển vòng lặp trong Java (break, continue)
Java Program to Implement Affine Cipher
Java Program to Implement Wagner and Fisher Algorithm for online String Matching
Period and Duration in Java
Lập trình đa luồng với Callable và Future trong Java
Tạo ứng dụng Java RESTful Client với thư viện OkHttp
Java Program to Represent Linear Equations in Matrix Form
Java Program to Find Minimum Element in an Array using Linear Search
Retrieve User Information in Spring Security
File Upload with Spring MVC
Java Program to do a Breadth First Search/Traversal on a graph non-recursively