​51nod3180 矩阵连乘​

该博客讨论了如何在给定多个矩阵时,通过利用结合律找到最小运算次数来相乘这些矩阵。介绍了问题背景,数据范围以及输入输出样例,并提供了动态规划的解决方案,转移方程为dp[i][j]=min(dp[i][j], dp[i][k]+dp[k+1][j]+a[i-1]*a[k]*a[j])。" 78604325,7359086,使用AngularJS实现的商品管理系统,"['前端开发', 'JavaScript', 'HTML', 'CSS', 'Angular']
摘要由CSDN通过智能技术生成

3180 矩阵连乘

有n个矩阵,大小分别为a[0]∗a[1],a[1]∗a[2],a[2]∗a[3],...,a[n−1]∗a[n],现要将它们依次相乘,只能使用结合率,求最少需要多少次运算。(2<=n<=1000 , a[i]<=100)

两个大小分别为p∗q和q∗r的矩阵相乘时的运算次数计为p∗q∗r。

注意不同的运算顺序会导致运算次数不一样,以样例为例:

如果我们先算前两个矩阵的乘积,将运算1∗10∗5=50次,并得到一个1∗5的矩阵,之后再算这个1∗5的矩阵和最后一个5∗20的矩阵的乘积,将运算1∗5∗20=100次,共运算150次;

如果我们先算后两个矩阵的乘积,将运算10∗5∗20=1000次,并得到一个10∗2010∗20的矩阵,之后再算第一个1∗10的矩阵和这个10∗20的矩阵的乘积,运算1∗10∗20=200次,共运算1200次。

输入

第一行输入一个整数n,表示矩阵的个数。
第二行输入n+1个数,表示给定的矩阵。

输出

输出一个整数,表示最少的运算次数。

数据范围

10% 2 <= n <= 10
30% 2 <= n <= 50
60% 2 <= n <= 100
100% 2 <
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值