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 Implement String Matching Using Vectors
Converting Java Date to OffsetDateTime
Guide to Guava Multimap
Documenting a Spring REST API Using OpenAPI 3.0
Remove All Occurrences of a Specific Value from a List
Upload and Display Excel Files with Spring MVC
Java Program to Implement Min Heap
Một số ký tự đặc biệt trong Java
Java Program to Check Whether a Weak Link i.e. Articulation Vertex Exists in a Graph
Java – Write an InputStream to a File
A Guide to the Java ExecutorService
Java Program to Permute All Letters of an Input String
Java – Rename or Move a File
Logging in Spring Boot
Automatic Property Expansion with Spring Boot
Java Program to Implement Interpolation Search Algorithm
Java Program to Implement Suffix Array
An Intro to Spring Cloud Task
How to Iterate Over a Stream With Indices
Date Time trong Java 8
Introduction to Using FreeMarker in Spring MVC
Java Byte Array to InputStream
Java Program to Describe the Representation of Graph using Adjacency List
Java Program to Perform Quick Sort on Large Number of Elements
Getting Started with GraphQL and Spring Boot
Call Methods at Runtime Using Java Reflection
Bootstrap a Web Application with Spring 5
Hướng dẫn tạo và sử dụng ThreadPool trong Java
Arrays.asList vs new ArrayList(Arrays.asList())
Marker Interface trong Java
Convert Hex to ASCII in Java
LinkedList trong java