Loading...

*矩阵连乘(java实现)*

**一、问题描述与分析**

问题:给定n个矩阵:A1,A2,...,An,其中Ai与Ai+1是可乘的,i=1,2...,n-1。确定计算矩阵连乘积的计算次序,使得依此次序计算矩阵连乘积需要的数乘次数最少。输入数据为矩阵个数和每个矩阵规模,输出结果为计算矩阵连乘积的计算次序和最少数乘次数。

分析:由于矩阵乘法满足结合律,故计算矩阵的连乘积可以有许多不同的计算次序。这种计算次序可以用加括号的方式来确定。若一个矩阵连乘积的计算次序完全确定,也就是说该连乘积已完全加括号,则可以依此次序反复调用2个矩阵相乘的标准算法计算出矩阵连乘积。

完全加括号的矩阵连乘积可递归地定义为:

(1)单个矩阵是完全加括号的;

(2)矩阵连乘积A是完全加括号的,则A可表示为2个完全加括号的矩阵连乘积B和C的乘积并加括号,即A=(BC)

例如,矩阵连乘积A1A2A3A4有5种不同的完全加括号的方式:(A1(A2(A3A4))),(A1((A2A3)A4)),((A1A2)(A3A4)),((A1(A2A3))A4),(((A1A2)A3)A4)。每一种完全加括号的方式对应于一个矩阵连乘积的计算次序,这决定着作乘积所需要的计算量。

**二、程序实现**

```java

import java.util.Scanner;

public class Matrix {

public static int n;

public static int[] p;

public static int[][] m;

public static int[][] s;

public static void main(String[] args)

{

Scanner in = new Scanner(System.in);

System.out.println("请输入矩阵的个数:");

n = in.nextInt();

System.out.println("请输入矩阵的行数和列数:");

p = new int[n+1];

for(int i = 0;i <= n;i++)

{

p[i] = in.nextInt();

}

m = new int[n+1][n+1];

s = new int[n+1][n+1];

matrixChain(p,n,m,s);

System.out.println("矩阵连乘的最小次数是:" + m[1][n]);

System.out.println("矩阵的连乘次序:");

Traceback(1,n,s);

}

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 matrixChain(int p[],int n,int[][] m,int[][] s)

{

for(int i = 1;i <= n;i++)//初始化,矩阵长度为1时,从i到i的矩阵连乘子问题只有一个矩阵,操作次数是0

{

m[i][i] = 0;

}

for(int r = 2;r <= n;r++)//矩阵的的长度,从长度2开始逐渐边长。

{

for(int i = 1;i <= n-r+1;i++)//从第i个矩阵开始,长度为r,则矩阵为(Ai-A(i+r-1))

{

int j = i+r-1;

m[i][j] = m[i+1][j] + p[i-1]*p[i]*p[j];

s[i][j] = i;//断开点的索引

for(int k = i+1;k < j;k++)//k从i+1循环找m[i][j]的最小值

{

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;//最小值的断开点

}

}

}

}

}

}

```

**三、实验结果与分析**

实验结果:

![结果][1]

实验分析:

思路:

设计算A[i:j],1≤i≤j≤n,所需要的最少数乘次数m[i,j],则原问题的最优值为m[1,n]。

当i=j时,A[i:j]=Ai,因此,m[i][i]=0,i=1,2,…,n

当i

递推关系如下:$$m[i,j]=\begin{cases}0,i=j\\\min_{i

若将对应m[i][j]的断开位置k记为s[i][j],在计算出最优值m[i][j]后,可递归地由s[i][j]构造出相应的最优解。s[i][j]中的数表明,计算矩阵链A[i:j]的最佳方式应在矩阵Ak和Ak+1之间断开,即最优的加括号方式应为(A[i:k])(A[k+1:j)。因此,从s[1][n]记录的信息可知计算A[1:n]的最优加括号方式为(A[1:s[1][n]])(A[s[1][n]+1:n]),进一步递推,A[1:s[1][n]]的最优加括号方式为(A[1:s[1][s[1][n]]])(A[s[1][s[1][n]]+1:s[1][s[1][n]]])。同理可以确定A[s[1][n]+1:n]的最优加括号方式在s[s[1][n]+1][n]处断开...照此递推下去,最终就可以确定A[1:n]的最优完全加括号方式,及构造出问题的一个最优解。

[1]: https://img.xiaowuyike.com/images/2020/07/06/juvflmigjpgo.md.png

最后修改:2020 年 07 月 06 日 06 : 27 PM

© 允许规范转载

赞赏

如果觉得对你有用,请随意赞赏

×Close

赞赏作者

扫一扫支付

支付宝支付

微信支付

java矩阵连乘算法_矩阵连乘(java实现)相关推荐

  1. python矩阵乘法分治算法_矩阵乘法的Strassen算法详解 --(算法导论分治法求矩阵)...

    1 题目描述 2 思路分析 3 解法 4 小结 1 题目描述 请编程实现矩阵乘法,并考虑当矩阵规模较大时的优化方法. 2 思路分析 根据wikipedia上的介绍:两个矩阵的乘法仅当第一个矩阵B的列数 ...

  2. java矩阵连乘算法_使用java写的矩阵乘法实例(Strassen算法)

    Strassen算法于1969年由德国数学家Strassen提出,该方法引入七个中间变量,每个中间变量都只需要进行一次乘法运算.而朴素算法却需要进行8次乘法运算. 原理 Strassen算法的原理如下 ...

  3. 矩阵相乘的strassen算法_矩阵乘法的Strassen算法+动态规划算法(矩阵链相乘和硬币问题)...

    矩阵乘法的Strassen 这个算法就是在矩阵乘法中采用分治法,能够有效的提高算法的效率. 先来看看咱们在高等代数中学的普通矩阵的乘法 两个矩阵相乘 上边这种普通求解方法的复杂度为: O(n3) 也称 ...

  4. java三元组的快速转置_矩阵压缩——三元组以及矩阵快速转置程序实现

    一.问题描述 将一个稀疏矩阵,用三元组的方式压缩存储,然后实现其快速转置 二.实验源码 #include #include #define Size 100 typedef struct { int ...

  5. [Java] 蓝桥杯ADV-208 算法提高 矩阵相乘

    问题描述 小明最近在为线性代数而头疼,线性代数确实很抽象(也很无聊),可惜他的老师正在讲这矩阵乘法这一段内容. 当然,小明上课打瞌睡也没问题,但线性代数的习题可是很可怕的. 小明希望你来帮他完成这个任 ...

  6. JAVA梅森旋转随机算法_伪随机数生成算法-梅森旋转(Mersenne Twister/MT)

    今天主要是来研究梅森旋转算法,它是用来产生伪随机数的,实际上产生伪随机数的方法有很多种,比如线性同余法, 平方取中法等等.但是这些方法产生的随机数质量往往不是很高,而今天介绍的梅森旋转算法可以产生高质 ...

  7. 二阶矩阵转置怎么求_矩阵求导术(下)

    本文承接上篇 https://zhuanlan.zhihu.com/p/24709748,来讲矩阵对矩阵的求导术.使用小写字母x表示标量,粗体小写字母 表示列向量,大写字母X表示矩阵.矩阵对矩阵的求导 ...

  8. 矩阵迹的性质_矩阵(含逆)的迹、行列式关于矩阵自身的导数计算与Maple验证...

    常见神经网络在计算相邻层权重关系式时,矩阵对矩阵求导所涉及的维度拼接操作对理论萌新往往不太友好:对于数据型为矩阵的最小二乘问题,尽管迹对矩阵求导操作十分实用但很多人仍习惯于逐项计算偏导.本文避开&qu ...

  9. ker矩阵是什么意思_矩阵光学

    前言 在看完<新概念物理教程 光学>以及<现代光学基础>后,大家都应该对几何光学.物理光学以及偏振光学有了比较清晰的认识.然而,传统的几何光学基本上就是套成像公式暴算或者特殊光 ...

  10. java jvm垃圾回收算法_深入理解JVM虚拟机2:JVM垃圾回收基本原理和算法

    本文转自互联网,侵删 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 喜欢的话麻烦点下Star哈 文章将同步到我的个人博客: www.how ...

最新文章

  1. 关于php的cgi,php-fpm的关系
  2. AndroidLinker与SO加壳技术之下篇
  3. 开源的.NET运行剖析器nprof简单使用指引
  4. easyui验证:validatebox
  5. 为什么我不推荐你使用vue-cli创建脚手架?
  6. 项目中会用到的开源项目列表
  7. 接口测试时,输入所有参数的参数值后,接口返回“参数错误:所有参数都不能为空”
  8. 设计模式-工厂模式(二)
  9. 朱光潜:要有悲剧,才能算人生
  10. ARM开发7.5.1 基础实训( 5 ) 4×4 矩阵键盘和 2 路 LED 显示系统( 1)--LPC21XX
  11. Apple Pay发展与安全
  12. 基于echarts+html+css+jq的数据可视化大屏展示炫酷看板[附源码]
  13. 推荐几个自己用过的软件测试博客论坛
  14. 2018年海峡两岸光电展将在台北举办
  15. mysql中获取时间的年月日_Mysql获取系统时间,年,月,日
  16. MATLAB | 生成视频文件
  17. 魅族手机调试出现is waiting for debugger的问题解决
  18. 计算机辅助医疗未来展望,数字骨科应用与展望:更精确、个性、直观的未来前景...
  19. find与ls命令合体坑总结
  20. ppt从第二页设置页码

热门文章

  1. 语音识别算法有哪些_语音识别特征提取方法
  2. MASR语音识别算法简介
  3. 16 计算二叉树叶子结点数目(耿 6.14)
  4. GitHub 上有哪些一般人也可以用的项目?
  5. linux fdisk指定ext4,如何在Linux中创建新的Ext4文件系统(分区)
  6. 微信小程序前端登录模块设计
  7. 数据库基本语句(SQL)
  8. latex 之好看的字体格式
  9. 智慧环境应急平台建设方案
  10. win32汇编--创建窗口程序(RadAsm)