首页 > 其他 > 详细

动态规划-矩阵链乘法

时间:2018-10-07 17:48:15      阅读:115      评论:0      收藏:0      [点我收藏+]

技术分享图片

Java实现:

package dp;

public class MatrixChainOrder {
    public static void matrixChainOrder(int[] p, int[][] m, int[][] s) {
        int n = p.length - 1;
        for (int i = 1; i <= n ; i++) {
            m[i][i] = 0;
        }
        for (int len = 2; len <= n; len++) {
            for (int i = 1; i <= n-len+1 ; i++) {
                int j = len + i - 1;
                m[i][j] = Integer.MAX_VALUE;
                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]) {
                        m[i][j] = q;
                        s[i][j] = k;
                    }
                }
            }
        }
    }

    public static void printOptimalSolution(int[][] s, int i, int j) {
        if (i == j) {
            System.out.print("A_" + i);
        } else {
            System.out.print("(");
            printOptimalSolution(s, i, s[i][j]);
            printOptimalSolution(s, s[i][j] + 1, j);
            System.out.print(")");
        }
    }

    public static void main(String[] args) {
        int[] p ={30, 35, 15, 5, 10, 20, 25};
        int n = p.length - 1;
        int[][] m = new int[n+1][n+1];
        int[][] s = new int[n+1][n+1];
        matrixChainOrder(p, m, s);
        System.out.println("The optimal value:" + m[1][n]);
        System.out.print("The optimal solution is:\n\t");
        printOptimalSolution(s, 1, n);
    }
}

 

动态规划-矩阵链乘法

原文:https://www.cnblogs.com/skyke/p/9750643.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!