- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
动态程序设计专题课件
动态程序设计专题; 动态程序设计是一种重要的算法设计技术。使用这种技术设计算法,能够高效地解决一类最优化问题。通常情况下,使用通常的递归策略求解这类最优化问题的时间复杂度是指数级的,而使用动态程序设计方法解决它们的复杂度往往是多项式级的。那么到底什么是动态规划,它能解决哪类最优化问题,它为什么有这么高的效率,如何实现它呢?;一、什么是动态程序设计;在多阶段决策问题中,各个阶段采取的决策,决策依赖于当前状态,又随即引起状态的转移,一个决策序列就是在变化的状态中产生出来的,故有“动态”的含义,我们称这种解决多阶段决策最优化的过程为动态规划程序设计方法。;二、简单的动态规划;输入数据:
由INPUT.TXT文件中首先读到的是三角形的行数。
例子中INPUT.TXT表示如下:
5
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
输出数据:
把最大总和(整数)写入OUTPUT.TXT文件。
上例为:
30;分析 ;对例1改变走向;例3、导弹拦截
某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统。但是这种拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭,由于该系统还在试用阶段。所以只有一套系统,因此有可能不能拦截所有的导弹。输入导弹数量N(1≤N≤1000)和导弹依次飞来的高度hi(雷达给出的高度不大于30000的正整数)。计算这套系统最多能拦截多少导弹,并依次打印输出被拦截导弹的高度。;分析:对于序列中任意一枚导弹i,假设它是一个可行序列中的最后一枚导弹,那么这个可行序列是前面1到i这些枚导弹中满足高度小于这枚导弹的高度的最长序列。设a[i]为每个导弹的高度,f[i]为以a[i]高度为序列中最后一枚导弹的最长序列,则
f[i]=max(f[k]+1){1=k=i-1,满足a[k]a[i]};例4:合唱队形
【问题描述】
N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形。
合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1, 2, …, K,他们的身高分别为T1, T2, …, TK,则他们的身高满足T1 T2 … Ti , Ti Ti+1 … TK (1 = i = K)。
你的任务是,已知所有N位同学的身高,计算最少需要几位同学出列,可以使得剩下的同学排成合唱队形。
【输入文件】
输入文件chorus.in的第一行是一个整数N(2 = N = 100),表示同学的总数。第一行有n个整数,用空格分隔,第i个整数Ti(130 = Ti = 230)是第i位同学的身高(厘米)。
【输出文件】
输出文件chorus.out包括一行,这一行只包含一个整数,就是最少需要几位同学出列。
;【样例输入】
8
186 186 150 200 160 130 197 220
【样例输出】
4
【数据规模】
对于50%的数据,保证有n = 20;
对于全部的数据,保证有n = 100。
分析:对于每个人来说,假设他是队伍中最高的,求出他前面的最长上升序列个数a[i],求出他后面下降序列序列的最长个数b[i],从而求出他作为队伍最高应出队人数n-a[i]-b[i]+1,这样找出n个人的最小值.问题解决.;三、背包问题;[样例]输入:24????? 一个整数,表示箱子容量6?????? 一个整数,表示有n个物品8?????? 接下来n行,分别表示这n个物品的各自体积。312797输出:?????? ? 0???????一个整数,表示箱子剩余空间。;例2:改变上题条件,每个物品有足够多(即可重复性背包问题);已知道空的猪猪背囊的重量E和装满金币的背囊的重量F。还知道一共有N种金币,其中第i种金币的面值为Pi,重量为Wi。知道了这些数据,请计算出猪猪背囊里的金币至少是多少钱。
输入:
输入文件第一行为两个正整数E,F(1=E=F=1000),E为空的猪猪背囊的重量,F为装满金币的猪猪背囊的重量。第二行为一个正整数N(1=N=50),表示金币的种类。接下来的N行,每行包含两个整数,第i+2行的两个数Pi和Wi分别表示第i种金币的面值和重量,1=Pi=60,1=Wi=100。
输出:
输出文件仅一行,如果所要求的最少钱数存在,则输出一个整数,为钱数X。否则,输出一行This is impossible. 。 ;样例输入:
pocket.in
10 110
2
1 1
30 50
样例输出:
pocket.out
60 ;四、动态规划的深入探讨;输入格式:
从文件读入数据,第一行为K、L,其中K=1
您可能关注的文档
最近下载
- 《混凝土结构加固设计规范》GB50367.pdf VIP
- 《精神疾病诊断与统计手册》DSM5.PDF VIP
- 2冷疗技术15课件讲解.pptx VIP
- 海姆立克急救法操作考核标准.doc VIP
- JJG 195-2019 连续累计自动衡器(皮带秤).pdf VIP
- 专项治理整改落实及长效机制建设情况报告().pdf VIP
- TD∕T 1087-2023 主体功能区优化完善技术指南.pdf
- (完整word版)数独题目100题(可打印).doc VIP
- 0604-会计专业国家技能人才培养工学一体化课程标准(试用).docx VIP
- 04.汉杂事秘辛.一卷.汉.阙名撰.明崇祯时期汲古阁刊本.pdf VIP
文档评论(0)