为了账号安全,请及时绑定邮箱和手机 立即绑定

动态规划——矩阵连乘(算法设计课题)

标签:
算法

问题描述:给定n个矩阵{A1,A2,…,An},其中Ai与Ai+1是可乘的,i=1,2 ,…,n-1。如何确定计算矩阵连乘积的计算次序,使得依此次序计算矩阵连乘积需要的数乘次数最少。例如:A1={30x35} ; A2={35x15} ;A3={15x5} ;A4={5x10} ;A5={10x20} ;A6={20x25} 最后的结果为:((A1(A2A3))((A4A5)A6))  最小的乘次为15125。

解题思路:能用动态规划的一个性质就是最优子结构性质,也就是说计算A[i:j]的最优次序所包含的计算矩阵子琏A[i:k]和A[k+1:j]的次序也是最优的。动态规划算法解此问题,可依据其递归式以自底向上的方式进行计算(即先从最小的开始计算)。在计算过程中,保存已解决的子问题答案。每个子问题只计算一次,而在后面需要时只要简单查一下,从而避免大量的重复计算,最终得到多项式时间的算法。我们可以根据下面这个公式来计算结果。其中p[i-1]表示的是第i个矩阵的行数,p[k]表示i:k矩阵合起来后最后得到的列数,p[j]是k+1:j合起来后得到的列数。这个部分的计算方法其实就是计算两个矩阵相乘时总共的乘次数。

从连乘矩阵个数为2开始计算每次的最小乘次数m[i][j]: m[0][1] m[1][2] m[2][3] m[3][4] m[4][5]  //m[0][1]表示第一个矩阵与第二个矩阵的最小乘次数

然后再计算再依次计算连乘矩阵个数为3:m[0][2] m[1][3] m[2][4] m[3][5]
            连乘矩阵个数为4:m[0][3] m[1][4] m[2][5]
          连乘矩阵个数为5:m[0][4] m[1][5]
          连乘矩阵个数为6:m[0][5]    //即最后我们要的结果


https://img1.sycdn.imooc.com//5b52b72200010d6c06530479.jpg




#include<stdio.h>int p[101],m[101][101],s[101][101];int n;void matrixChain(){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 = r+i-1;m[i][j]=m[i][i]+m[i+1][j]+p[i-1]*p[i]*p[j];s[i][j]=i;for(int k = i+1;k<j;k++){int temp=m[i][k]+m[k+1][j]+p[i-1]*p[k]*p[j];if(temp<m[i][j]){m[i][j]=temp;s[i][j]=k;}}}}void traceback(int i,int j){if(i==j)return ;traceback(i,s[i][j]);traceback(s[i][j]+1,j);printf("Multiply A[%d,%d]and A[%d,%d]\n",i,s[i][j],s[i][j]+1,j);}int main(){while(~scanf("%d",&n)){for(int i=0;i<=n;i++)scanf("%d",&p[i]);matrixChain();traceback(1,n);printf("%d\n",m[1][n]);}return 0;}


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中

九日王朝

手记
粉丝
41
获赞与收藏
185

关注作者,订阅最新文章

阅读免费教程

  • Python 算法入门教程
    15个小节 26304 1027
  • 算法入门教程
    15个小节 31514 662
  • 后端通用面试教程
    41个小节 29768 332
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 分销返利 帮助中心 APP下载
官方微信
返回顶部

举报

0/150
提交
取消

PHP网站源码布吉百度关键词包年推广广州英文网站建设丹竹头企业网站设计横岗网页制作南山企业网站设计南联网络推广永湖SEO按天扣费沙井百姓网标王大鹏网站优化排名观澜如何制作网站布吉设计网站东莞网站推广系统大鹏百搜词包大浪网站制作设计大浪网站优化软件南山如何制作网站石岩网站优化软件宝安优秀网站设计坑梓百姓网标王南澳网站搭建坂田seo网站优化惠州网站推广方案大芬网站优化按天扣费民治SEO按效果付费丹竹头网站优化推广光明百搜标王永湖网站建设设计坑梓外贸网站制作大芬seo宝安关键词排名歼20紧急升空逼退外机英媒称团队夜以继日筹划王妃复出草木蔓发 春山在望成都发生巨响 当地回应60岁老人炒菠菜未焯水致肾病恶化男子涉嫌走私被判11年却一天牢没坐劳斯莱斯右转逼停直行车网传落水者说“没让你救”系谣言广东通报13岁男孩性侵女童不予立案贵州小伙回应在美国卖三蹦子火了淀粉肠小王子日销售额涨超10倍有个姐真把千机伞做出来了近3万元金手镯仅含足金十克呼北高速交通事故已致14人死亡杨洋拄拐现身医院国产伟哥去年销售近13亿男子给前妻转账 现任妻子起诉要回新基金只募集到26元还是员工自购男孩疑遭霸凌 家长讨说法被踢出群充个话费竟沦为间接洗钱工具新的一天从800个哈欠开始单亲妈妈陷入热恋 14岁儿子报警#春分立蛋大挑战#中国投资客涌入日本东京买房两大学生合买彩票中奖一人不认账新加坡主帅:唯一目标击败中国队月嫂回应掌掴婴儿是在赶虫子19岁小伙救下5人后溺亡 多方发声清明节放假3天调休1天张家界的山上“长”满了韩国人?开封王婆为何火了主播靠辱骂母亲走红被批捕封号代拍被何赛飞拿着魔杖追着打阿根廷将发行1万与2万面值的纸币库克现身上海为江西彩礼“减负”的“试婚人”因自嘲式简历走红的教授更新简介殡仪馆花卉高于市场价3倍还重复用网友称在豆瓣酱里吃出老鼠头315晚会后胖东来又人满为患了网友建议重庆地铁不准乘客携带菜筐特朗普谈“凯特王妃P图照”罗斯否认插足凯特王妃婚姻青海通报栏杆断裂小学生跌落住进ICU恒大被罚41.75亿到底怎么缴湖南一县政协主席疑涉刑案被控制茶百道就改标签日期致歉王树国3次鞠躬告别西交大师生张立群任西安交通大学校长杨倩无缘巴黎奥运

PHP网站源码 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化