java
程序员文章站
2022-06-19 13:56:38
...
java实现矩阵相乘的算法如下:
public class matrixChain {
public static void MatrixChain(int[] p,int n, int[][] m, int[][] s) {
for (int i = 1; i <= n; i++) {
m[i][i] = 0;
}
for(int r = 2;r <= n; r++ ) {
for(int i = 1; i <= n-r+1; i++) {
int j = i+r-1;
m[i][j] =1000000;
s[i][j] = i;
for(int k = i+1; k < j; k++) {
int t = m[i][k] + m[k+1][j] + p[i-1]*p[k]*p[j];
if(t < m[i][j]) {
m[i][j] = t;
s[i][j] = k;
}
}
}
}
}
public static void Traceback(int i, int j, int[][] s) {
if(i == j) return;
Traceback(i,s[i][j],s);
Traceback(s[i][j] + 1,j,s);
System.out.println("Multiply A" + i + ".." + s[i][j] + "and A" + (s[i][j] + 1) + ".." + j);
}
public static void main(String[] args) {
System.out.println("测试的结果如下:");
Matrix mc = new Matrix();
int n = 7;
int p[] = { 30, 35, 15, 5, 10, 20, 25 };
int m[][] = new int[n][n];
int s[][] = new int[n][n];
int l = p.length-1;
mc.MatrixChain(p, l,m, s);
for (int i = 1; i < n; i++) {
for (int j = 1; j < n; j++) {
System.out.print(m[i][j]+ "\t");
}
System.out.println();
}
System.out.println();
for (int i = 1; i < n; i++) {
for (int j = 1; j < n; j++) {
System.out.print(s[i][j]+" ");
}
System.out.println();
}
mc.Traceback( 1, 6, s);
}
}