动态规划试题
动态规划练习试题和解答

动态规划练习题[题1] 多米诺骨牌(DOMINO)问题描述:有一种多米诺骨牌是平面的,其正面被分成上下两部分,每一部分的表面或者为空,或者被标上1至6个点。
现有一行排列在桌面上:顶行骨牌的点数之和为6+1+1+1=9;底行骨牌点数之和为1+5+3+2=11。
顶行和底行的差值是2。
这个差值是两行点数之和的差的绝对值。
每个多米诺骨牌都可以上下倒置转换,即上部变为下部,下部变为上部。
现在的任务是,以最少的翻转次数,使得顶行和底行之间的差值最小。
对于上面这个例子,我们只需翻转最后一个骨牌,就可以使得顶行和底行的差值为0,所以例子的答案为1。
输入格式:文件的第一行是一个整数n(1〈=n〈=1000〉,表示有n个多米诺骨牌在桌面上排成一行。
接下来共有n行,每行包含两个整数a、b(0〈=a、b〈=6,中间用空格分开〉。
第I+1行的a、b分别表示第I个多米诺骨牌的上部与下部的点数(0表示空)。
输出格式:只有一个整数在文件的第一行。
这个整数表示翻动骨牌的最少次数,从而使得顶行和底行的差值最小。
[题2] Perform巡回演出题目描述:Flute市的Phlharmoniker乐团2000年准备到Harp市做一次大型演出,本着普及古典音乐的目的,乐团指挥L.Y.M准备在到达Harp市之前先在周围一些小城市作一段时间的巡回演出,此后的几天里,音乐家们将每天搭乘一个航班从一个城市飞到另一个城市,最后才到达目的地Harp市(乐团可多次在同一城市演出).由于航线的费用和班次每天都在变,城市和城市之间都有一份循环的航班表,每一时间,每一方向,航班表循环的周期都可能不同.现要求寻找一张花费费用最小的演出表.输入: 输入文件包括若干个场景.每个场景的描述由一对整数n(2<=n<=10)和k(1<=k<=1000)开始,音乐家们要在这n个城市作巡回演出,城市用1..n标号,其中1是起点Flute市,n是终点Harp市,接下来有n*(n-1)份航班表,一份航班表一行,描述每对城市之间的航线和价格,第一组n-1份航班表对应从城市1到其他城市(2,3,...n)的航班,接下的n-1行是从城市2到其他城市(1,3,4...n)的航班,如此下去.每份航班又一个整数d(1<=d<=30)开始,表示航班表循环的周期,接下来的d个非负整数表示1,2...d天对应的两个城市的航班的价格,价格为零表示那天两个城市之间没有航班.例如"3 75 0 80"表示第一天机票价格是75KOI,第二天没有航班,第三天的机票是80KOI,然后循环:第四天又是75KOI,第五天没有航班,如此循环.输入文件由n=k=0的场景结束.输出:对每个场景如果乐团可能从城市1出发,每天都要飞往另一个城市,最后(经过k天)抵达城市n,则输出这k个航班价格之和的最小值.如果不可能存在这样的巡回演出路线,输出0.样例输入: 样例输出:3 6 4602 130 150 03 75 0 807 120 110 0 100 110 120 04 60 70 60 503 0 135 1402 70 802 32 0 701 800 0[题3] 复制书稿(BOOKS)问题描述:假设有M本书(编号为1,2,…M),想将每本复制一份,M本书的页数可能不同(分别是P1,P2,…PM)。
动态规划试题

动态规划试题动态规划装箱问题(01背包):有⼀个箱⼦容量为VV(正整数,0≤V≤20000),同时有n个物品(024 68 3 12 7 9 7输出:0f[j]=max(f[j],f[j-w[i]]+w[i]);f[j] 为:当总容量为j 时,不放第i 件物品,所能装的最⼤体积。
f[j-w[i]]+w[i] 为:当总容量为j 时,放了第i 件物品后,所能装的最⼤体积。
(即j减去第i 件物品体积的容量能装的最⼤体积+第i 件物品的体积。
w[i] 为第i 件物品体积)背包的种类:背包分为01背包,多重背包以及完全背包这三种基本模型,其他的背包问题都是从这3种背包中延申出来的。
完全背包的模板题⾯是这样的:设有n种物品,每种物品有⼀个重量及⼀个价值。
但每种物品的数量是⽆限的,同时有⼀个背包,最⼤载重量为M,今从n种物品中选取若⼲件(同⼀种物品可以⽆限选取),使其重量的和⼩于等于M,⽽价值的和为最⼤。
完全背包[⽆限量]的采摘药输⼊:70 371 10069 11 2输出:140每个数组在满⾜条件,可以遍历多次01背包实现代码:采药-传送门输⼊:70 371 10069 11 2输出:3每个数组遍历⼀遍题⽬描述⾦明今天很开⼼,家⾥购置的新房就要领钥匙了,新房⾥有⼀间他⾃⼰专⽤的很宽敞的房间。
更让他⾼兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过N元钱就⾏”。
今天⼀早⾦明就开始做预算,但是他想买的东西太多了,肯定会超过妈妈限定的N元。
于是,他把每件物品规定了⼀个重要度,分为5等:⽤整数1-5表⽰,第5等最重要。
他还从因特⽹上查到了每件物品的价格(都是整数元)。
他希望在不超过N元(可以等于N 元)的前提下,使每件物品的价格与重要度的乘积的总和最⼤。
设第jj件物品的价格为v_[j],重要度为w_[j],共选中了k件物品,编号依次为j_1,j_2,…,j_k,则所求的总和为:w_[j_k]v[j1]×w[j1]+v[j2]×w[j2]+…+v[jk]×w[jk]。
动态规划练习题

最小乘车费用 (bus)【问题描述】而任意一辆汽车从不行驶超过1 0公里。
某人想乘车到达n公里远的地方,假设他可以任意次换车,请你帮他找到一种乘车方案,使得总费用最小。
注意:1 0公里的费用比1公里小的情况是允许的。
【输入文件】共两行:第一行为1 0个不超过200的整数,依次表示行驶1~1 0公里的费用,相邻两数间用一个空格隔开:第二行为某人想要乘车的公里数(不超过20000的整数)。
【输出文件】仅一行,包含一个整数,表示到达n公里所需要的最小费用。
【样例输入】12 21 31 40 49 58 69 79 90 10115【样例输出】147船 (ships)【问题描述】PALMIA国家被一条河流分成南北两岸,南北两岸上各有N个村庄。
北岸的每一个村庄有一个唯一的朋友在南岸,且他们的朋友村庄彼此不同。
每一对朋友村庄想要一条船来连接他们,他们向政府提出申请以获得批准。
由于河面上常常有雾,政府决定禁止船只航线相交(如果相交,则很可能导致碰船)。
你的任务是编写一个程序,帮助政府官员决定批准哪些船只航线,使得不相交的航线数目最大。
【输入文件】ships.in输入文件由几组数据组成。
每组数据的第一行有2个整数X,Y,中间有一个空格隔开,X代表PALMIA河的长度(10<=X<=6000),Y代表河的宽度(10<=Y<=100)。
第二行包含整数N,表示分别坐落在南北两岸上的村庄的数目(1<=N<=5000)。
在接下来的N行中,每一行有两个非负整数C,D,由一个空格隔开,分别表示这一对朋友村庄沿河岸与PALMIA 河最西边界的距离(C代表北岸的村庄,D代表南岸的村庄),不存在同岸又同位置的村庄。
最后一组数据的下面仅有一行,是两个0,也被一空格隔开。
【输出文件】ships.out对输入文件的每一组数据,输出文件应在连续的行中表示出最大可能满足上述条件的航线的数目。
【输入样例】30 4722 42 610 315 129 817 174 20 0【输出样例】4DOLLARS (dollars)【问题描述】在以后的若干天里戴维将学习美元与德国马克的汇率。
动态规划习题

习题6-1. 考虑下面的网络图,箭头上的数字代表相连两个节点之间的距离。
(1)用动态规划找出从节点1到节点10的最短路。
(2)从节点4到节点10的最短路呢?6-2. 从北京到上海的包机的剩余装载能力为2000kg ,某一运输公司现有4种货物需要从北京运输到上海。
每种货物的单位、单位重量和单位运输费用如下表所示。
(1)用动态规划找出包机应该运输的每种货物的单位数。
(2)假设包机同意装载另一批货物,剩余装载能力降为1800kg ,计算结果会怎样变化?6-3. 假定有一个3阶段的过程,每一阶段的产量是需要做出决策的函数。
使用数学符号,问题表述如下:Max ()()()332211d r d r d r ++ s.t.1000321≤++d d d 每个阶段的决策变量和相应的返回值如下所示:6-4. 某制造公司为一家汽车工厂提供发动机的部件,以下是3个月的生产计划的数据。
量是10单位,并且生产批量是10的倍数(例如,10,20或者30单位)。
6-5. 某物流公司雇佣了8名新员工,现决定如何把他们分配到4项作业上。
公司给出了以下每项作业分配不同的作业人员的估计利润表。
(1) 用动态规划决定每项作业应该分配的新员工数目。
(2) 如果公司只雇佣了6名新员工,应该把这些员工分配给哪些作业?6-6. 一个锯木厂采购了一批20ft 长的原木,想要把这些原木切成更短的原木,然后把切后的小原木卖给制造公司。
制造公司已经订购了一批4种尺寸的原木:l 1=3ft ,l 2=7ft ,l 3=11ft ,l 4=16ft 。
锯木厂现在有2000个长度为20ft 的原木的库存,并希望有选择地裁截原木以最大化利润。
假定锯木厂的订单是无限的,唯一的问题就是确定把现有原木裁成的类型以最大化利润。
原木的利润如下表所示:任何裁截类型的长度限制如下:201173321≤++d d d 其中,i d 是长度为i l 的类型的裁截数目,4,3,2,1=i .(1)为这个问题建立动态规划模型,并使用模型解决问题。
动态规划习题

动态规划专题分类视图数轴动规题: (1)较复杂得数轴动规 (4)线性动规 (7)区域动规: (14)未知得动规: (20)数轴动规题:题1、2001年普及组第4题--装箱问题【问题描述】有一个箱子容量为V(正整数,0≤V≤20000),同时有n个物品(0<n≤30),每个物品有一个体积(正整数)。
要求从n个物品中,任取若干个装入箱内,使箱子得剩余空间为最小。
【输入格式】输入文件box、in有若干行。
第一行:一个整数,表示箱子容量V;第二行:一个整数,表示物品个数n;接下来n行,分别表示这n个物品得各自体积。
【输出格式】输出文件box、out只有一行数据,该行只有一个数,表示最小得箱子剩余空间。
【输入样例】2468312797【输出样例】题2、1996年提高组第4题--砝码秤重 __数据加强版【问题描述】设有n种砝码,第k种砝码有C k个,每个重量均为W k,求:用这些砝码能秤出得不同重量得个数,但不包括一个砝码也不用得情况。
【输入格式】输入文件weight、in得第一行只有一个数n,表示不同得砝码得种类数、第2行至第n+1行,每行有两个整数、第k+1行得两个数分别表示第k种砝码得个数与重量、【输出格式】输出文件weight、out中只有一行数据:Total=N。
表示用这些砝码能秤出得不同重量数。
【输入样例】22 22 3【输出样例】Total=8【样例说明】重量2,3,4,5,6,7,8,10都能秤得【数据限制】对于100%得数据,砝码得种类n满足:1≤n≤100;对于30%得数据,砝码得总数量C满足:1≤C≤20;对于100%得数据,砝码得总数量C满足:1≤C≤100;对于所有得数据,砝码得总重量W满足:1≤W≤400000;题3、石子归并-szgb、pas【问题描述】有一堆石头质量分别为W1,W2,…,Wn、(Wi≤10000),将石头合并为两堆,使两堆质量得差最小。
【输入】输入文件szgb、in得第一行只有一个整数n(1≤n≤50),表示有n堆石子。
动态规划习题完整版

动态规划习题Document serial number【NL89WT-NY98YT-NC8CB-NNUUT-NUT108】动态规划专题分类视图数轴动规题:题1.2001年普及组第4题--装箱问题【问题描述】有一个箱子容量为V(正整数,0≤V≤20000),同时有n个物品(0<n≤30),每个物品有一个体积(正整数)。
要求从n个物品中,任取若干个装入箱内,使箱子的剩余空间为最小。
【输入格式】输入文件box.in有若干行。
第一行:一个整数,表示箱子容量V;第二行:一个整数,表示物品个数n;接下来n行,分别表示这n个物品的各自体积。
【输出格式】输出文件box.out只有一行数据,该行只有一个数,表示最小的箱子剩余空间。
【输入样例】2468312797【输出样例】题2.1996年提高组第4题--砝码秤重__数据加强版【问题描述】设有n种砝码,第k种砝码有Ck 个,每个重量均为Wk,求:用这些砝码能秤出的不同重量的个数,但不包括一个砝码也不用的情况。
【输入格式】输入文件weight.in的第一行只有一个数n,表示不同的砝码的种类数.第2行至第n+1行,每行有两个整数.第k+1行的两个数分别表示第k种砝码的个数和重量.【输出格式】输出文件weight.out中只有一行数据:Total=N。
表示用这些砝码能秤出的不同重量数。
【输入样例】22223【输出样例】Total=8【样例说明】重量2,3,4,5,6,7,8,10都能秤得【数据限制】对于100%的数据,砝码的种类n满足:1≤n≤100;对于30%的数据,砝码的总数量C满足:1≤C≤20;对于100%的数据,砝码的总数量C满足:1≤C≤100;对于所有的数据,砝码的总重量W满足:1≤W≤400000;题3.石子归并-szgb.pas【问题描述】有一堆石头质量分别为W1,W2,…,Wn.(Wi≤10000),将石头合并为两堆,使两堆质量的差最小。
【输入】输入文件szgb.in的第一行只有一个整数n(1≤n≤50),表示有n堆石子。
动态规划 练习题

23.(11分)请用动态规划逆序求解法求解下列问题:求出下图中从A到E的最短路线及长度。
在图中标出每个点到终点的最短距离。
24. (11分)一个旅行者从A点出发,经过B、C、D等处,到达E。
各地间距离如图中所示。
问该旅行者应选择哪一条路线,使从A到E的总路程最短?(可直接在图上标号,最后给定答案)
24.一个旅行者从A点出发,经过B、C、D等处,到达E。
各地间距离如图中所示。
问该旅行者应选择哪一条路线,使从A到E的总路程最短?(可直接在图上标号,最后给定答案)(11分)
解:此为动态规划之“最短路问题”,可用逆向追踪“图上标号法”解决如下:
最佳策略为:A →B 2→C 1→D 1→E 或A →B 3→C 1→D 1→E 此时从A 到E 的总路程的最短距离都是11
23. 请用动态规划逆序求解法求解下列问题:
各点标号依次为:A:8, B1:7,B2:6, B3:8, C1:5, C2:4,D1:3,D2:1,D3:5.
25. 某厂生产C B A ,,三种产品,其所需劳动力、材料等有关数据见下表。
要求:建立模型,并用单纯形法计算,确定获利最大的产品生产计划。
解:(1)设C B A ,,
各生产321,,x x x 件。
有
32143min x x x z ++=
st.⎪⎩⎪
⎨⎧=≥≤++≤++)3,2,1(,03054345
536321321j x x x x x x x j
(4分)
获利最大的生产计划是C B A ,,各生产5件、0件、3件,最大利润为273453=⨯+⨯=z 元。
(15分)。
动态规划题目

动态规划总结1.POJ 1160Post OfficeTime Limit: 1000MS Memory Limit: 10000KTotal Submissions: 17936 Accepted: 9655DescriptionThere is a straight highway with villages alongside the highway. The highway is represented as an integer axis, and the position of each village is identified with a single integer coordinate. There are no two villages in the same position. The distance between two positions is the absolute value of the difference of their integer coordinates.Post offices will be built in some, but not necessarily all of the villages. A village and the post office in it have the same position. For building the post offices, their positions should be chosen so that the total sum of all distances between each village and its nearest post office is minimum.You are to write a program which, given the positions of the villages and the number of post offices, computes the leastpossible sum of all distances between each village and its nearest post office.IntputYour program is to read from standard input. The first line contains two integers: the first is the number of villages V, 1 <= V <= 300, and the second is the number of post offices P, 1 <= P <= 30, P <= V. The second line contains V integers in increasing order. These V integers are the positions of the villages. For each position X it holds that 1 <= X <= 10000. outputThe first line contains one integer S, which is the sum of all distances between each village and its nearest post office. Sample input10 51 2 3 6 7 9 11 22 44 50Sample output9题目大意:用数轴描述一条高速公路,有V个村庄,每一个村庄坐落在数轴的某个点上,需要选择P个村庄在其中建立邮局,要求每个村庄到最近邮局的距离和最小。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
}
dp[0] = A[0];
for(int i=1; i < n; i++){
dp[i] = max(A[i],dp[i-1]+A[i]);
}
sort(dp,dp+n);
cout << dp[n-1] << endl;
return 0;
}
6
-2 11 -4 13 -5 -2
输出:20
}
for(int i=n-1; i >=0; i--){
for(int j=0; j <= i; j++){
dp[i][j] = max(dp[i+1][j],dp[i+1][j+1]) + a[i][j];
}
}
cout << dp[0][0] << endl;
return 0;
}
②
//最大连续子序列和
}
for(int i=1; i <= n; i++){
for(int j=0; j <= m; j++){
for(int k=0; k <= s[i] && k*v[i] <= j; k++){
f[i][j] = max(f[i][j],f[i-1][j-k*v[i]]+k*w[i]);
}
}
}
cout << f[n][m];
int n,m;
cin >> n >> m;
for(int i=1; i <= m; i++){
cin >> a[i] >> b[i];
}
for(int i=1; i<=m; i++){
for(int j=a[i]; j <=n; j++){
f[j] = max(f[j],f[j-a[i]]+b[i]);
}
}
cout << f[n];
return 0;
}
01背包
实现代码:采药-传送门
输入:
70 3
71 100
69 1
1 2
输出:3
每个数组遍历一遍
#include<iostream>
#include<algorithm>
using namespace std;
int a[101],b[101];
int f[10001];
int dp[maxn][maxn];
int main(){
完全背包
[无限量]的采摘药输入:
70 3
71 100
69 1
1 2
输出:140
每个数组在满足条件,可以遍历多次
#include<iostream>
#include<algorithm>
using namespace std;
int f[100001];
int a[10001],b[10001];
int main(){
int main()
{
cin >> n >> m;
int cnt = 0;
for (int i = 1; i <= n; i ++ )
{
int a, b, s;
cin >> a >> b >> s;
int k = 1;
while (k <= s)
{
cnt ++ ;
v[cnt] = a * k;
w[cnt] = b * k;
using namespace std;
int f[20005],w[35];
int main()
{
int v,n;
cin>>v&;=n;i++)cin>>w[i];
for(int i=1;i<=n;i++){
for(int j=v;j>=w[i];j--){
f[j]=max(f[j],f[j-w[i]]+w[i]);
s -= k;
k *= 2;
}
if (s > 0)
{
cnt ++ ;
v[cnt] = a * s;
w[cnt] = b * s;
}
}
n = cnt;
for (int i = 1; i <= n; i ++ )
for (int j = m; j >= v[i]; j -- )
f[j] = max(f[j], f[j - v[i]] + w[i]);
}
}
cout<<v-f[v];
return 0;}
f[j]=max(f[j],f[j-w[i]]+w[i]);
f[j]为:当总容量为j时,不放第i件物品,所能装的最大体积。
f[j-w[i]]+w[i]为:当总容量为j时,放了第i件物品后,所能装的最大体积。(即j减去第i件物品体积的容量能装的最大体积+第i件物品的体积。w[i]为第i件物品体积)
int main(){
int n,m;
cin >> n >> m;
for(int i=1; i <= m; i++){
cin >> a[i] >> b[i];
}
for(int i=1; i <=m; i++){
for(int j=n; j >= a[i]; j--){
f[j] = max(f[j],f[j-a[i]]+b[i]);
if(A[i] > A[j] && (dp[j] + 1) > dp[i]){
dp[i] = dp[j] + 1;
}
}
ans = max(ans,dp[i]);
}
cout << ans << endl;
return 0;
}
④
//最长公共子序列
给定两个长度分别为N和M的字符串A和B,求既是A的子序列又是B的子序列的字符串长度最长是多少。
动态规划
装箱问题(01背包):
有一个箱子容量为VV(正整数,0≤V≤20000),同时有n个物品(0<n≤30,每个物品有一个体积(正整数)。要求n个物品中,任取若干个装入箱内,使箱子的剩余空间为最小。
24 6
8 3 12 7 9 7
输出:0
#include<iostream>
#include<cstdio>
}
for(int i=1; i <= m; i++){
for(int j=n; j >= k[i]; j--){
f[j] = max(f[j],f[j-k[i]]+k[i]*v[i]);
}
}
cout << f[n];
return 0;
}
多重背包
有N种物品和一个容量是V的背包。
第ii种物品最多有sisi件,每件体积是vivi,价值是wiwi。
输入样例:
5
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
输出样例:
30
#include<iostream>
#include<algorithm>
const int MAXV = 10010;
using namespace std;
int dp[MAXV][MAXV];
int main(){
int n;
输入样例
4 5
1 2 3
2 4 1
3 4 3
4 5 2
输出样例:
10
#include <iostream>
#include <algorithm>
using namespace std;
const int N = 12010, M = 2010;
int n, m;
int v[N], w[N];
int f[M];
const int maxn = 110;
int n,m;
int v[maxn],w[maxn],s[maxn];
int f[maxn][maxn];
int main(){
cin >> n >> m;
for(int i=1; i <= n; i++){
cin >> v[i] >> w[i] >> s[i];
从第2行到第m+1行,第jj行给出了编号为j-1的物品的基本数据,每行有2个非负整数v p(其中vv表示该物品的价格(v≤10000),p表示该物品的重要度(1-5)
输出格式
1个正整数,为不超过总钱数的物品的价格与重要度乘积的总和的最大值(<100000000)。
输入:
1000 5
800 2
400 5
#include<iostream>
#include<algorithm>
using namespace std;