版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
动态规划算法和实例分析动态规划简介0-1背包问题最长公共子序列动态规划算法和实例分析动态规划简介动态规划简介动态规划的基本思想动态规划(DP:DynamicProgramming)是一种重要的程序设计手段,其基本思想是在对一个问题的多阶段决策中,按照某一顺序,根据每一步所选决策的不同,会引起状态的转移,最后会在变化的状态中获取到一个决策序列。
动态规划就是为了使获取的决策序列在某种条件下达到最优。动态规划是一种将多阶段决策过程转化为一系列单阶段问题,然后逐个求解的程序设技方法。引例:已知6种物品和一个可载重量为60的背包,物品i(i=1,2,…,6)的重量wi分别为(15,17,20,12,9,14),产生的效益pi分别为(32,37,46,26,21,30)。装包时每一件物品可以装入,也可以不装,但不可拆开装。确定如何装包,使所得装包总效益最大。动态规划简介动态规划的基本思想动态规划简介动态规划的基本思想引例分析多阶段决策问题,装每一件物品就是一个阶段,每个阶段都有一个决策:物品装还是不装。约束条件和目标函数按照单位效益最大化装包,得xi的序列为(0,1,1,1,1,0),总效益为130按重量最大化装包,得xi的序列为(0,1,1,0,1,1),总效益为134结论:决策序列(0,1,1,0,1,1)为最优决策序列
动态规划简介动态规划的基本思想
动态规划简介动态规划的步骤将所求最优化问题分成若干个阶段,找出最优解的性质,并刻画其结构特征。将问题发展到各个阶段时所处的不同状态表示出来,确定各个阶段状态之间的递推关系,并确定初始(边界)条件。应用递推求解最优值。根据计算最有值时所得到的信息,构造最优解。动态规划问题的特征最优子结构。问题的最优解包含了其子问题的最优解,则称该问题具有最优子结构性质。重叠子问题。用递归算法自顶向下解问题时,有些子问题会被反复计算多次,称这些字问题重叠。动态规划算法利用这种子问题重叠性质,对每个字问题只解一次(保存下来),已有尽可能多的利用这些子问题的解。动态规划简介动态规划的步骤动态规划算法和实例分析动态规划简介0-1背包问题最长公共子序列动态规划算法和实例分析动态规划简介0-1背包问题
0-1背包问题
0-1背包问题逆推动态规划算法设计建立递推关系设m(i,j)为背包容量j,可取物品范围为i,i+1,…,n的最大效益值。则当0<=j<w(i)时,物品i不可能装入,最大效益值与m(i+1,j)相同;当j>=w(i)时,有两种选择:⑴不装入物品i,这时的最大效益值与m(i+1,j)相同;⑵装入物品i,这时会产生效益p(i),背包剩余容量为j-w(i),可以选择物品i+1,…,n来装,最大效益值为m(i+1,j-w(i))+p(i);0-1背包问题逆推动态规划算法设计0-1背包问题
0-1背包问题
0-1背包问题逆推动态规划算法设计最优值计算⑴根据边界条件计算m(n,j)for(j=0;j<=c;j++)
//计算m(n,j)if(j>=w[n])m[n][j]=p[n];elsem[n][j]=0;0-1背包问题逆推动态规划算法设计⑴根据边界条件计算m(n,0-1背包问题逆推动态规划算法设计最优值计算⑵逆推计算m(i,j)for(i=n-1;i>=1;i--)//逆推计算m(i,j),i=n-1...1for(j=0;j<=c;j++)if(j>=w[i]&&m[i+1][j]<m[i+1][j-w[i]]+p[i]) m[i][j]=m[i+1][j-w[i]]+p[i]; else m[i][j]=m[i+1][j];⑶经过上述推导,最优值在m[1][c]中。最优值推导示例0-1背包问题逆推动态规划算法设计⑵逆推计算m(i,j)最0-1背包问题逆推动态规划算法设计构造最优解—步骤1ifm(i,cw)>m(i+1,cw),i=1,2,…,n-1则x(i)=1,装载w(i);其中:cw从c开始(cw=c),cw=cw-x(i)*w(i)else
x(i)=0,不装载w(i);cw=c;for(sp=0,sw=0,i=1;i<=n-1;i++)if(m[i][cw]>m[i+1][cw]) //x(i)=1,装载w(i){cw-=w[i]; //cw=cw-x(i)*w(i)sw+=w[i];sp+=p[i];printf("%2d\t%3d\t%3d\n",i,w[i],p[i]);}0-1背包问题逆推动态规划算法设计cw=c;0-1背包问题逆推动态规划算法设计构造最优解—步骤2比较所装载的物品效益之和与最优值,决定w(n)是否装载,方法:
if(m[1][c]-效益之和)等于物品n的效益p[n]
装入w(n)if(m[1][c]-sp==p[n]) //判断w(n)是否装载{sw+=w[i];sp+=p[i];printf("%2d\t%3d\t%3d\n",n,w[n],p[n]);}knapsack(0-1)0-1背包问题逆推动态规划算法设计if(m[1][c]-sp动态规划算法和实例分析动态规划简介0-1背包问题最长公共子序列动态规划算法和实例分析动态规划简介最长公共子序列最长公共子序列概念子序列一个给定序列的子序列是在该序列中删去若干元素后所得到的序列。即:给定X={x1,x2,…,xm}和Z={z1,z2,…,zk},X的子序列是指存在一个严格递增下标序列{i1,i2,…,ik},使得对于所有的j=1,2,…k,有zj=xij。例如: Z={b,d,c,a}是X={a,b,c,d,c,b,a}的一个子序列公共子序列若序列Z是序列X的子序列,又是序列Y的子序列,则称Z是序列X和序列Y的公共子序列。例如:
序列"bcba"是"abcbdab"与"bdcaba"的公共子序列最长公共子序列最长公共子序列概念最长公共子序列问题描述给定两个序列X={x1,x2,…,xm}和Y={y1,y2,…,yn},找出序列X和Y的最长公共子序列。最长公共子序列问题描述最长公共子序列
最长公共子序列
最长公共子序列
最长公共子序列
最长公共子序列逆推动态规划算法设计——计算最优值⑴根据边界条件计算c(i,n)和c(m,j)m=strlen(x);n=strlen(y);for(i=0;i<=m;i++)c[i][n]=0;for(j=0;j<=n;j++)c[m][j]=0;最长公共子序列逆推动态规划算法设计——计算最优值⑴根据边界条最长公共子序列逆推动态规划算法设计——计算最优值⑵逆推计算c(i,j)for(i=m-1;i>=0;i--)for(j=n-1;j>=0;j--)if(x[i]==y[j])c[i][j]=c[i+1][j+1]+1;else{if(c[i][j+1]>c[i+1][j])c[i][j]=c[i][j+1];elsec[i][j]=c[i+1][j];}⑶经过上述推导,最优值在c[0][0]中。最优值推导示例最长公共子序列逆推动态规划算法设计——计算最优值⑵逆推计算c最长公共子序列逆推动态规划算法设计——构造最优解为了能够构造最优解,在逆推计算最优值的过程中,利用s(i,j)记录x(i)与y(j)比较的结果:当x(i)=y(j)时,s(i,j)=1当x(i)!=y(j)时,s(i,j)=0X序列的每一项与Y序列的每一项逐一比较,根据s(i,j)与c(i,j)的取值构造最长公共子序列。对x(i)与y(j)比较,其中i=0,1,…,m-1;j=t,…n-1(t从0开始),当确定最长公共子序列中的一项时,通过t=t+1操作避免重复取项。若s(i,j)=1且c(i,j)=c(0,0)时,取x(i)为最长公共序列中的第1项。若s(i,j)=1且c(i,j)=c(0,0)-w时,取x(i)为最长公共序列中的第w项(其中,w从0开始,每确定最长公共子序列中的一项,w增一)。最长公共子序列逆推动态规划算法设计——构造最优解最长公共子序列逆推动态规划算法设计——构造最优解
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 中药材金融介绍
- 《昆山装饰预算培训》课件
- 《语文知识竞赛赛》课件
- 2024年度影视制作分包授权协议3篇
- 2024品牌授权合作合同-教育科技品牌授权协议3篇
- 《难忘埃及》课件
- 劳动合同员工评价
- 劳动合同考勤表举证
- 2024年版的海洋货物运输保险合同范本
- 垃圾场填埋运营管理合同
- 浸出工艺说明
- 机械原理课程设计——压床机构设计
- 青稞粉青稞系列产品加工扩建项目可行性研究报告模板-立项备案
- 减速机CAD版图纸
- 公司人事档案管理办法规章制度
- 工程观测、试验资料的整理与分析
- 卵巢过度刺激综合征患者的护理
- 【原创】小学体育与健康(水平二)三年级《原地侧向投掷沙包》教学设计
- 师带徒工作考核评价办法
- 硫酸根定量测量方法
- 李居明饿命改运学(绝密资料)
评论
0/150
提交评论