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:
Spring RestTemplate Request/Response Logging
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Uploading MultipartFile with Spring RestTemplate
Converting a Stack Trace to a String in Java
Java CyclicBarrier vs CountDownLatch
Java Program to Perform Preorder Non-Recursive Traversal of a Given Binary Tree
Java Program to Find Location of a Point Placed in Three Dimensions Using K-D Trees
JUnit5 Programmatic Extension Registration with @RegisterExtension
Spring @Primary Annotation
Java Program to Implement Dijkstra’s Algorithm using Queue
REST Web service: Tạo ứng dụng Java RESTful Client với Jersey Client 2.x
Hướng dẫn Java Design Pattern – Decorator
Intro to the Jackson ObjectMapper
Find the Registered Spring Security Filters
HttpClient 4 Cookbook
Java Program for Douglas-Peucker Algorithm Implementation
Configure a RestTemplate with RestTemplateBuilder
Send email with JavaMail
Java Program to Find the Longest Path in a DAG
Java Program to Implement Uniform-Cost Search
New in Spring Security OAuth2 – Verify Claims
Introduction to Spring Cloud CLI
Lập trình đa luồng với CompletableFuture trong Java 8
Apache Commons Collections MapUtils
Truyền giá trị và tham chiếu trong java
Java Multi-line String
Encode/Decode to/from Base64
Rest Web service: Filter và Interceptor với Jersey 2.x (P1)
Spring Boot - Service Components
Java Program to Implement Solovay Strassen Primality Test Algorithm
Java Program to subtract two large numbers using Linked Lists
Một số tính năng mới về xử lý ngoại lệ trong Java 7