ImageVerifierCode 换一换
格式:DOC , 页数:3 ,大小:42KB ,
资源ID:7807114      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-7807114.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(矩阵乘法最优算法.doc)为本站会员(dwy79026)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

矩阵乘法最优算法.doc

1、动态规划实现1动态规划算法实现姓名:赵成兵学号:20062353班级:软件工程 2 班1. 问题描述多个矩阵做乘法时最多的操作是做乘法运算,矩阵乘法是满足结合律的,不同的结合方式乘法运算次数相差非常大,在矩阵的阶较大和矩阵数目很大时,这成为制约程序效率的关键,穷举找出最优结合方式显然是无效的,结合方式非常的多。所以利用动态规划解决此问题,给出最少的乘法次数。2算法设计思想及描述动态规划思想类似于分治,总是把规模较大的问题分解成小的问题加以求解,原问题的解依赖于子问题的解,还有一个显著特征就是原问题最优解的条件就是子问题的最优。不同的地方就是子问题树中的子问题大量重复出现。为减少运算,总是在第一

2、次遇到时计算并保存计算结果,以后遇到直接使用即可。动态规划求解算法,通常按以下几个步骤进行。(1) 分析最优解性质,刻画其结构特征(2) 递归定义最优值(3) 自底向上的方式计算最优解(4) 根据计算最优值得到的信息,构造一个最优解本问题是最小乘次数,定义最优结构 10minikjkjmij kjp说明:当 i 等于 j 时,取 mij为 0,否则取另外一个值, 这时递归算最优乘次基础。3 算法分析动态规划算法可以解决的问题有一个特点,就是问题本身的最优是在子问题的最优方案基础上的。这个算法只是给出了给定矩阵序列乘积所要计算的最少次数,并没有给出给出如何最终的每次计算结合方式,但是在每次构造最

3、优解时,数组 result保存了截断点的位置,即每次计算时结合断开的下标 k,通过递归到最后只剩 2 个数组时所有的矩阵相乘的结合方式就确定下来。即间接给出了如何计算的方案。可用动态规划算法求解的问题还具备另外一个要素就是子问题的重叠性质,在递归 算法自顶向下求解问题时,每次产生的子问题不是新问题,有些子问题被反复计算多次。正是这样,只是在第一次遇到问题时计算并保存结果,以后直接使用,这个算法只需多项式的事件,效率较高。动态规划实现2矩阵乘法最优算法代码。 (最终版)#include “stdio.h“#define N 50#define M 50#define O 50#define MA

4、X 65535/为保持一定兼容性,相乘次数不应超过整数的表示范围void main()int aN,mmNM,resultNM;/mmij数组保存的是最少相乘次数,其中 i 是开始的数组,j 是最优的数组,i 从 1 开始有效int i,j,k,t,l,temp,rr;int n;printf(“input the number of arrays:n“);scanf(“%d“,printf(“input the right xishu:n“);/输入的时候重复的数据只输入一次for(i=0;irr+1;i+)scanf(“%d“,n=rr;for(i=1;i=n;i+)mmii=0;/数组本

5、身和自己相乘,最少次数为 0 次for(l=2;l=n;l+)for(i=1;i=n-l+1;i+)j=i+l-1;mmij=MAX;/开始时赋值为最大值,无穷大的意思for(k=i;k=j-1;k+)temp=mmik+mmk+1j+ai-1*ak*aj;/if(tempmmij)mmij=temp;/取得最小的次数resultij=k;/保存每次截断的位置,非常重要printf(“the most proper times is:%dn“,mm1n);动态规划实现34 运行环境Windows XP 系统,VC+6.05 程序结果分析说明,输入的行和列时遇到重复的数只输入一次即可,这就是为什么程序运行例子中8 个矩阵相乘,输入的是 9 的数据的原因了。值得注意的是,编程中使用的数据是 int 类型的,所以矩阵个数不能太大,不然最后结果超出了 int 的表示范围而发生错误。程序优劣比较,程序完成了问题要求的计算,但是在输入的时候不太符合平时的习惯,不太让人满意,如果规模很大,则需要改动下程序。

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报