- 1、本文档共74页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
本讲纲要⊕-动态规划 数塔问题 1 贪婪算法 2 枚举算法 3 动态规划的手工计算 4 动态规划的算法实现 5 动态规划的思想和概念 6 动态规划的经典实例 数塔问题 例5.1 数塔问题 有形如右图的一个数塔,从顶部出发,在每一结点可以选择向左走或是向右走,一直走到底层,要求找出一条路径,使路径上的数值和最大。 1 贪婪算法 贪婪策略? 2 枚举 最保险的思路,列举出所有可能的 路径再比较,得出和最大的路径。 2 枚举-递归 3 动态规划的手工计算 3 动态规划的手工计算 3 动态规划的手工计算 顺序与逆序解法本质上无区别; 4 动态规划的算法实现 原始信息存储 层数用整型变量n存储; 数塔中的数据用二维数组data[ ][ ]存储,下三角阵。 4 动态规划的算法实现 输出data[1][1]“9”; b=d[1][1]-data[1][1]=59-9=50 b与d[2][1],d[2][2] 比较b与d[2][1]相等,输出data[2][1]“12”; b=d[2][1]-data[2][1]=50-12=38 b与d[3][1],d[3][2] 比较b与d[3][1]相等,输出data[3][1]“10”; b=a[3][1]-data[3][1]=38-10=28 b与d[4][1],d[4][2] 比较b与d[4][2]相等,输出data[4][2]“18”; b=d[4][2]-data[4][2]=28-18=10 b与d[5][2],d[5][3] 比较b与d[5][3]相等,输出data[5][3]“10” 。 4 动态规划的算法实现 为了设计简洁的算法,可以用三维数组a[50][50][3]存储以上确定的三个数组的信息。 a[50][50][1]代替数组data, a[50][50][2]代替数组d, a[50][50][3]记录解路径。 5 动态规划的思想和概念-基本思想 动态规划的基本思想 动态规划方法的基本思想是,把求解的问题分成许多阶段或多个子问题,然后按顺序求解各子问题。最后一个子问题就是初始问题的解。 5 -空间换取时间 5 -主要概念 阶段:把问题分成几个相互联系的有顺序的几个环节,这些环节即称为阶段。 状态:某一阶段的出发位置称为状态。通俗地说状态是对问题在某一时刻的进展情况的数学描述。 决策:从某阶段的一个状态演变到下一个阶段某状态的选择。 状态转移方程:根据上一阶段的状态和决策导出本阶段的状态。这就像是“递推”。 5 -主要概念-数塔问题 阶段:每行就是一个阶段; 5 -递归实现 int a[100][100], f[100][100]; int max(int i,int j,int n) { int left,right; if ((i==n)||(j==n)) f[i][j] =a[i][j]; if (f[i][j] != -1) return f[i][j]; left=max(i+1,j,n); //左边 right=max(i+1,j+1,n); //右边 return (f[i][j] = (leftright)? (left+a[i][j]):(right+a[i][j])); } 5 -适合解决的问题的性质 动态规划算法的问题及决策应该具有两个性质:最优化原理、无后向性。 1) 最优化原理(或称为最佳原则、最优子结构); 2) 无后向性(无后效性):某阶段状态一旦确定以后,就不受这个状态以后决策的影响。即某状态以后的过程不会影响以前的状态,只与当前状态有关。 5 -适合解决的问题的性质-数塔问题 最优化原理(最优子结构) 9-12-10-18-10 显然12-10-18-10也是12到最后一层的最大和…… 5 -设计步骤 设计动态规划算法的基本步骤 设计一个标准的动态规划算法的步骤: 1) 划分阶段; 2) 选择状态; 3) 确定决策并写出状态转移方程。 例5.2 资源分配问题 设有资源n(n为整数),分配给m个项目,gi(x)为第i个项目分得资源x(x为整数)所得到的利润。 求总利润最大的资源分配方案,也就是解下列问题: max z=g1(x1)+ g2(x2)+……gm(xm) x1+x2+x3+……xm = n,0≤xi≤n,i=1,2,3,……,m 函数gi(x)以数据表的形式给出。 例5.2 例5.2 手算怎么算? 例5.2 例5.2 例5.2 例 5.2 数据结构设计: 一维数组q:原始数据(逐行使用); 一维数组f:当前最大收益情况; 一维数组temp:正在计算的最大收益; 二维数组a:前i个项目投资j获得最大利润时,给第i个项目分配的资源数(m*(n+1)维); 一维数组gain:在不同投资数下获最
您可能关注的文档
- -土壤胶体与土壤吸收性能.ppt
- +UG编程+自动编程基础.ppt
- ---单项式.ppt
- ----去括号.ppt
- +电气控制设计中主要参数计算及常用元件选择.ppt
- +有机化合物的分类及命名.ppt
- +UG编程+车削编程基础.ppt
- --如何进行课题研究.ppt
- -奥美广告文案写作培训材料.ppt
- -构成物质的基本微粒.ppt
- 2024高考物理一轮复习规范演练7共点力的平衡含解析新人教版.doc
- 高中语文第5课苏轼词两首学案3新人教版必修4.doc
- 2024_2025学年高中英语课时分层作业9Unit3LifeinthefutureSectionⅢⅣ含解析新人教版必修5.doc
- 2024_2025学年新教材高中英语模块素养检测含解析译林版必修第一册.doc
- 2024_2025学年新教材高中英语单元综合检测5含解析外研版选择性必修第一册.doc
- 2024高考政治一轮复习第1单元生活与消费第三课多彩的消费练习含解析新人教版必修1.doc
- 2024_2025学年新教材高中英语WELCOMEUNITSectionⅡReadingandThi.doc
- 2024_2025学年高中历史专题九当今世界政治格局的多极化趋势测评含解析人民版必修1.docx
- 2024高考生物一轮复习第9单元生物与环境第29讲生态系统的结构和功能教案.docx
- 2024_2025学年新教材高中英语UNIT5LANGUAGESAROUNDTHEWORLDSect.doc
文档评论(0)