数学模型-贪心算法及实例PPT课件
合集下载
贪心算法精品PPT课件
– 从全局看来,运用贪心策略解决的问题在 程序的运行过程中无回溯过程
教学进度
背包问题
计算机科学与工程系
• 给定n种物品和一个背包。物品i的重量是 Wi,其价值为Vi,背包的容量为C。在选 择物品i装入背包时,可以选择物品i的一部 分,而不一定要全部装入背包,1≤i≤n。 应如何选择装入背包的物品,使得装入背包 中物品的总价值最大?
教学进度
计算机科学与工程系
• 贪心算法并不总能求得问题的整体最优 解。但对于活动安排问题,贪心算法 GreedySelector却总能求得的整体最 优解,即它最终所确定的相容活动集合 A的规模最大。
教学进度
贪心算法的基本要素
• 最优子结构性质 • 贪心选择性质
计算机科学与工程系
教学进度
最优子结构性质
教学进度
计算机科学与工程系
• 怎样对这n个活动进行安排才能 令最多的活动可以使用资源?
教学进度
计算机科学与工程系
• 活动安排问题也就是要在所给 的活动集合中选出最大的相容 活动子集合
教学进度
计算机科学与工程系
教学进度
计算机科学与工程系
• 思路:按照结束时间递增序列将活动排 序,使得f1<=f2<=…<=fn
• void GreedySelector(int n, Type s[], Type f[], bool A[])
•{
•
A[1]=true;
•
int j=1;
•
for (int i=2;i<=n;i++) {
各活动的起始时间和结 束时间存储于数组s和f 中且按结束时间的非减 序排列
•
if (s[i]>=f[j]) { A[i]=true; j=i; }
教学进度
背包问题
计算机科学与工程系
• 给定n种物品和一个背包。物品i的重量是 Wi,其价值为Vi,背包的容量为C。在选 择物品i装入背包时,可以选择物品i的一部 分,而不一定要全部装入背包,1≤i≤n。 应如何选择装入背包的物品,使得装入背包 中物品的总价值最大?
教学进度
计算机科学与工程系
• 贪心算法并不总能求得问题的整体最优 解。但对于活动安排问题,贪心算法 GreedySelector却总能求得的整体最 优解,即它最终所确定的相容活动集合 A的规模最大。
教学进度
贪心算法的基本要素
• 最优子结构性质 • 贪心选择性质
计算机科学与工程系
教学进度
最优子结构性质
教学进度
计算机科学与工程系
• 怎样对这n个活动进行安排才能 令最多的活动可以使用资源?
教学进度
计算机科学与工程系
• 活动安排问题也就是要在所给 的活动集合中选出最大的相容 活动子集合
教学进度
计算机科学与工程系
教学进度
计算机科学与工程系
• 思路:按照结束时间递增序列将活动排 序,使得f1<=f2<=…<=fn
• void GreedySelector(int n, Type s[], Type f[], bool A[])
•{
•
A[1]=true;
•
int j=1;
•
for (int i=2;i<=n;i++) {
各活动的起始时间和结 束时间存储于数组s和f 中且按结束时间的非减 序排列
•
if (s[i]>=f[j]) { A[i]=true; j=i; }
[数学]152 贪心算法ppt课件
S { 0,1,2,3,4,5}
35 53
Prim算法实现 int s[N]表示集合S,1表示曾经参与,否那么0
,初始S[0] = 1; lowcost[N]记录每一个顶点到集合s的最短边长
度,初始lowcost[0, ..., N-1] = c[0][0, ..., N-1] lowcost[N] ={0,4,INT_MAX, 5, INT_MAX,
就根据部分最优战略,得到一个部分解,减少 问题的范围或规模 选择最早终了的事件; 将一切的部分解综合列;
13 53
二:区间覆盖问题
问题的描画
用整数i来表示x轴上坐标为[i - 1, i]的区间(长度 为1)。给出M(1 <= M <= 200)个不同的整数, 表示M个这样的区间。
2 53
背包问题: 给定n种物品和一个背包,设Wi为物体i的分量
,Vi为期价值,C为背包的承分量。要求在背 包的承分量的限制下,进能够使背包中物品 的价值最大。 贪婪战略一:每次选择价值最大的物品。 贪婪战略二:每次选择分量最小的物品。 贪婪战略三:每次选择Vi/Wi最大的物品
3 53
什么是贪婪法? “鼠目寸光〞的方法?每次选择面值最大的硬币
10 53
#include <iostream> using namespace std; const int N = 12; void OutputResult(int select[], int N) //输出结果函数 {
for(int i = 0; i < N; i++) {
if(select[i] == 1) //当标志为1时该事件被选中 cout << i << endl; } }
35 53
Prim算法实现 int s[N]表示集合S,1表示曾经参与,否那么0
,初始S[0] = 1; lowcost[N]记录每一个顶点到集合s的最短边长
度,初始lowcost[0, ..., N-1] = c[0][0, ..., N-1] lowcost[N] ={0,4,INT_MAX, 5, INT_MAX,
就根据部分最优战略,得到一个部分解,减少 问题的范围或规模 选择最早终了的事件; 将一切的部分解综合列;
13 53
二:区间覆盖问题
问题的描画
用整数i来表示x轴上坐标为[i - 1, i]的区间(长度 为1)。给出M(1 <= M <= 200)个不同的整数, 表示M个这样的区间。
2 53
背包问题: 给定n种物品和一个背包,设Wi为物体i的分量
,Vi为期价值,C为背包的承分量。要求在背 包的承分量的限制下,进能够使背包中物品 的价值最大。 贪婪战略一:每次选择价值最大的物品。 贪婪战略二:每次选择分量最小的物品。 贪婪战略三:每次选择Vi/Wi最大的物品
3 53
什么是贪婪法? “鼠目寸光〞的方法?每次选择面值最大的硬币
10 53
#include <iostream> using namespace std; const int N = 12; void OutputResult(int select[], int N) //输出结果函数 {
for(int i = 0; i < N; i++) {
if(select[i] == 1) //当标志为1时该事件被选中 cout << i << endl; } }
贪心算法PPT学习课件
5
例8.2 一个买糖的孩子用1元钱买了不到1元钱的糖,售货 员找硬币时希望用最少个数的硬币。 售货员每增加一个硬币,使用的贪心规则是: 每次希望增加尽可能多的币值,又不能超出总数。 例如要找66c(分)。
● 假设硬币面值分别为:25c, 10c, 5c, 1c。
● 假设硬币面值分别为:20c, 16c, 10c, 1c。
3. MAKESET({v})
4. End for
5. T={}
6. While |T|<n-1
7. 令(x,y)为E中的下一条边
8. If FIND(x)≠FIND(y) then
heyichao@
26
9.
将(x,y)加入T
10.
UNION(x,y)
11. End if
12. End while
● 函数H-1(w)返回w在H中的位置 (注意堆由一个 数组H(1…n)来实现)。
heyichao@
18
● 运行时间主要取决于堆运算,这里共有n-1 个DELETEMIN运算,n-1个INSERT运算,最 多m-n+1个SIFTUP运算,每个堆运算用O(logn) 时间,得到总共需要O(mlogn)时间。
1. 对G的边以非降序权重排列。
2. 对于排序表中的每条边,如果现在把它放入T 不会形成回路的话,则把它加入到生成树T中;否 则将它丢弃。
见例8.3
heyichao@
24
Kruskal算法的实现
为有效地实现此算法,我们需要某种机制来检 测加入边后是否构成回路。为此需要确定一种数 据结构,让它在算法的每个时刻来表示森林,并 且在向T中添加边时动态检测是否有回路生成。
7
● 假设V={1,2,…,n}并且s=1。这个问题可以用一 种称为Dijkstra算法的贪心技术来解决。初始时, 将顶点分为两个集合X={1}和Y={2,3,…,n}。X包 含的顶点集合:从源点到这些顶点的距离已经确 定。
简单的贪心算法pptPPT课件
问题的整体最优解 中包含着它子问题 的最优解
【常见应用】背包问题,最小生成树,最短路径,作业调度等等 【算法优点】求解速度快,时间复杂性有较低的阶. 【算法缺点】需证明是最优解.
02.08.2021
编辑版pppt
9
ﻻ常见应用
1、活动安排问题
【问题陈述】设有n个活动E={1,2,…,n}要使用同一资源,同一时间内 只允许一个活动使用该资源. 设活动i的起止时间区间[si, fi) ,如果选
02.08.2021
编辑版pppt
10
ﻻ常见应用
活动安排问题贪心算法: void GreedySelector(int n, Type s[], Type f[], bool A[]) {
A[1]=true; int j=1; for (int i=2;i<=n;i++) {
if (s[i]>=f[j]) { A[i]=true; j=i; }
else A[i]=false; } }
02.08.2021
编辑版pppt
11
ﻻ常见应用
2、多机调度问题
多机调度问题要求给出一种作业调度方案,使所给的n 个作业在尽可能短的时间内由m台机器加工处理完成。
约定,每个作业均可在任何一台机器上加工处理,但未完 工前不允许中断处理。作业不能拆分成更小的子作业。
体上考虑并不一定是最优解;
(2)贪心算法只能用来求某些最大或最小解的 问题;
(3)贪心算法只能确定某些问题的可行性范围
。
因此,贪心算法具有局限性,并不是总能得到最优
解。 02.08.2021
编辑版pppt
16
谢谢观 看!!!
02.08.2021
《贪心算法》PPT课件
{x1,x2,x3} {1,2/15,0} { 0,2/3,1} {0,1,1/2} {...}
n
wixi
20
i1
n
vixi
i1
20
20
...
31
...
[算法思路]1).将各物体按单位价值由高到低排序. 2).取价值最高者放入背包. 3).计算背包剩余空间. 4).在剩余物体中取价值最高者放入背包. 若背包剩余容量=0或物体全部装入背包为止
这种策略下的量度是已装入物品的累计效益值与所用 容量之比。
(v2/w2 , v3/w3 , v1/w1 )=(24/15,15/10, 25/18) 先装入重量为15的物品2,在装入重量为5的物品3, ∑pixi =24+15*5/10=31.5。此结果为最优解。
算法设计与分析 > 贪心算法
[例] n=3,c=20 (v1,v2,v3)=(25,24,15),(w1,w2,w3)=(18,15,10)
[常见应用]背包问题,最小生成树,最短路径,作业调度等等 [算法优点]求解速度快,时间复杂性有较低的阶. [算法缺点]需证明是最优解.
[适用问题] 具备贪心选择和最优子结构性质的最优化问题 贪心选择性质:整体的最优解可通过一系列局部最优解达到,即
贪心选择到达。
贪心算法通常以自顶向下的方式进行,以迭代的方式作出相
精选ppt13最优化描述找一个n元向量x44背包问题knapsackproblemmax问题描述设有n个物体和一个背包物体i的重量为w1装入背包则具有价值为v目标是找到一个方案使放入背包的物体总价值最高贪心算法精选ppt141652425121502028202312031011220315算法设计与分析贪心算法精选ppt151用贪心策略求解背包问题时首先要选出最优的度量标准
算法课件(五)贪心算法
最大值。
• 贪心算法在每一步的决策中虽然没有完全顾忌到问题整体 优化,但在局部择优中是朝着整体优化的方向发展的。为 此,贪心算法首先要确定一个度量准则(称为贪心准则), 每一步都是按这个准则选取优化方案。
贪心算法抽象化控制流程
Greedy(A, n) // A[1:n]代表那个输入 1. solution={}; //解向量初始化为空集 2. for i to n do 3. x:=Select(A) 4. if Feasible(solution, x) then 5. solution:=Union(solution, x) 6. end if 7. End for 8. Return (solution)
• 据此,贪心准则应当是:在未安排的活动中挑选结束时间
最早的活动安排。 • 在贪心算法中,将各项活动的开始时间和结束时间分别用 两个数组s和f存储,并使得数组中元素的顺序按结束时间 非减序排列:f1≤ f2≤…≤ fn。
[算法思路]将n个活动按结束时间非减序排列,依次考虑活动i,
若i与已选择的活动相容,则添加此活动到相容活动子集. [例]设待安排的11个活动起止时间按结束时间的非减序排列
作业集E的子集称为相容的,如果其中的作业可以被安排
由一台机器完成。带限期单机作业安排问题就是要在所 给的作业集合中选出总效益值最大的相容子集。
例如:n=4,(p1,p2,p3,p4)={100,10,15,20},
(d1,d2,d3,d4)={2,1,2,1}
• 例子 设n=7, (p1, p2,… , pn)=(35,30,25,20,15,10,5), (d1, d2,… ,dn)=(4,2,4,3,4,8,3), • 算法GreedyJob的执行过程可描述如下: d1; d2, d1; d2, d1,d3; d2, d4, d1,d3; d2, d4, d1,d3, d6; 4 ; 2, 4 ; 2, 4, 4 ; 2, 3, 4, 4 ; 2, 3, 4, 4, 8;
贪心算法PPT课件
且有||B’-{k}||>||B-{1}||,这与假设2°矛盾。 ▌
安排方案
f1
B
安排方案
fk
B’
…… 共j个活动
可能 相同 不存在
……
可能
如果 B’包 含这 个活, 则B 一定 包含
9
(2) 时间复杂度分析: 因为排序过程可以在O(nlogn)时间内完成,而求最优活动子 集的过程只需O(n)次比较,因此这个算法的时间复杂度为 O(nlogn)。 (3) 贪心策略设计算法的一般特点
·选Si最小的,这样可以增大场地的利用率; ·选fi最小的,使得下一个活动可以更早开始。
由于活动的占用时间长度没有限制,因此后一选择更合理。
6
为了在每一次选择时取当前可以安排的活动中最早结束的活动,应首先把 n项活动按结束时间的先后进行升序排序。即,使f1≤f2≤…≤fn,然后在Si值 不小于当前时刻的活动中取fi值最小者。 算法:
·算法的设计比较简单; ·算法一般比较快速; ·算法的正确性一般不明显,需要论证;如果正确性不能保 证,那么它往往可以得到近似最优解。
10
5.2 背包(Knapsack)问题
1. 问题描述
已知:n个(应为n种)物体{1,2,…,n}与一个背包。物体i的重量 (或体积)为Wi>0,价值为Pi>0(i=1,2,…,n),背包容量为 M>0。
计算机算法 ——设计与分析导论
刘璟
1
Chapter 5. 贪心(Greedy)技术
❖ 5.1 贪心策略的思想 ❖ 5.2 背包(Knapsack)问题 ❖ 5.3 Huffman编码 ❖ 5.4 多机调度问题的近似解法 ❖ 5.5 单源最短路径的Dijkstra算法
安排方案
f1
B
安排方案
fk
B’
…… 共j个活动
可能 相同 不存在
……
可能
如果 B’包 含这 个活, 则B 一定 包含
9
(2) 时间复杂度分析: 因为排序过程可以在O(nlogn)时间内完成,而求最优活动子 集的过程只需O(n)次比较,因此这个算法的时间复杂度为 O(nlogn)。 (3) 贪心策略设计算法的一般特点
·选Si最小的,这样可以增大场地的利用率; ·选fi最小的,使得下一个活动可以更早开始。
由于活动的占用时间长度没有限制,因此后一选择更合理。
6
为了在每一次选择时取当前可以安排的活动中最早结束的活动,应首先把 n项活动按结束时间的先后进行升序排序。即,使f1≤f2≤…≤fn,然后在Si值 不小于当前时刻的活动中取fi值最小者。 算法:
·算法的设计比较简单; ·算法一般比较快速; ·算法的正确性一般不明显,需要论证;如果正确性不能保 证,那么它往往可以得到近似最优解。
10
5.2 背包(Knapsack)问题
1. 问题描述
已知:n个(应为n种)物体{1,2,…,n}与一个背包。物体i的重量 (或体积)为Wi>0,价值为Pi>0(i=1,2,…,n),背包容量为 M>0。
计算机算法 ——设计与分析导论
刘璟
1
Chapter 5. 贪心(Greedy)技术
❖ 5.1 贪心策略的思想 ❖ 5.2 背包(Knapsack)问题 ❖ 5.3 Huffman编码 ❖ 5.4 多机调度问题的近似解法 ❖ 5.5 单源最短路径的Dijkstra算法
第五讲 贪心算法PPT课件
• Begin
•
S:=S+P[I]; M:=M-W[I];
• End
• Else {否则取一部分}
• Begin
•
S:=S+M*(P[I]/W[I]); Break;
• End;
• End;
11
• Procedure Out; {输出} • Begin • Assign(Output,Fout); Rewrite(Output); • Writeln(S:0:0); • Close(Output); • End; • Begin {主程序} • Init; • Work; • Out; • End.
23
• 分析:需要考虑如下问题: • (1)出发前汽车的油箱是空的,故汽车必须在起
点(1号站)处加油。加多少油? • (2)汽车行程到第几站开始加油,加多少油? • 可以看出,原问题需要解决的是在哪些油站加油
• (2) 原问题的最优解包含子问题的最优解,即问题具有最优 子结构的性质。在背包问题中,第一次选择单位质量最大的货 物,它是第一个子问题的最优解,第二次选择剩下的货物中单 位重量价值最大的货物,同样是第二个子问题的最优解,依次 类推。
• 其次,如何选择一个贪心标准?正确的贪心标准可以得到问 题的最优解,在确定采用贪心策略解决问题时,不能随意的判 断贪心标准是否正确,尤其不要被表面上看似正确的贪心标准 所迷惑。在得出贪心标准之后应给予严格的数学证明。
二
请在这里输入您的主要 叙述内容
三 请在这里输入您的主要叙述内容
2
一、引入:
• 若在求解一个问题时,能根据每次所得 到的局部最优解,推导出全局最优或最优 目标。那么,我们可以根据这个策略,每 次得到局部最优解答,逐步而推导出问题, 这种策略称为贪心法。
算法-第4章贪心法-PPT课件
f i A
i , j A , i j , f ( i ) t f ( j ) or f ( j ) t f ( i ) i j
12
实例
A={1, 2, 3, 4, 5}, T=<5, 8, 4, 10, 3>, D=<10, 12, 15, 11, 20> 调度1: f1(1)=0, f1(2)=5, f1(3)=13, f1(4)=17, f1(5)=27 各任务延迟:0, 1, 2, 16, 10; 最大延迟:16 5 1 2 13 3 17 4 27 5 30
18
i j
f2(j)=s f2(i)=s+tj
delay(f’,i)=s+tj+ti- di <delya(f,j)r delay(f, j)=s+ti+tj-dj
4.3 得不到最优解的处理方法
讨论对于哪些输入贪心法能得到最优解:输入条件 讨论贪心法的解最坏情况下与最优解的误差(见第8章)
例4.4 找零钱问题 设有 n 种零钱, 重量分别为w1, w2, ... , wn, 价值分别为 v1=1, v2, ... , vn. 需要付的总钱数是 Y .不妨设币值和钱数都为 正整数. 问:如何付钱使得所付钱的总重最轻?
设计思想:按完成时间从早到晚安排任务,没有空闲
15
交换论证:正确性证明
算法的解的性质: (1) 没有空闲时间, 没有逆序. (2) 逆序 (i, j): f(i) < f(j) 且 di > dj 引理4.1 所有没有逆序、没有空闲时间的调度具有相同的 最大延迟. 证: 设 f 没有逆序,在 f 中具有相同完成时间的客户i1, i2, … , ik 必被连续安排. 在这k个客户中最大延迟是最后一个客 户,被延迟的时间是 k
i , j A , i j , f ( i ) t f ( j ) or f ( j ) t f ( i ) i j
12
实例
A={1, 2, 3, 4, 5}, T=<5, 8, 4, 10, 3>, D=<10, 12, 15, 11, 20> 调度1: f1(1)=0, f1(2)=5, f1(3)=13, f1(4)=17, f1(5)=27 各任务延迟:0, 1, 2, 16, 10; 最大延迟:16 5 1 2 13 3 17 4 27 5 30
18
i j
f2(j)=s f2(i)=s+tj
delay(f’,i)=s+tj+ti- di <delya(f,j)r delay(f, j)=s+ti+tj-dj
4.3 得不到最优解的处理方法
讨论对于哪些输入贪心法能得到最优解:输入条件 讨论贪心法的解最坏情况下与最优解的误差(见第8章)
例4.4 找零钱问题 设有 n 种零钱, 重量分别为w1, w2, ... , wn, 价值分别为 v1=1, v2, ... , vn. 需要付的总钱数是 Y .不妨设币值和钱数都为 正整数. 问:如何付钱使得所付钱的总重最轻?
设计思想:按完成时间从早到晚安排任务,没有空闲
15
交换论证:正确性证明
算法的解的性质: (1) 没有空闲时间, 没有逆序. (2) 逆序 (i, j): f(i) < f(j) 且 di > dj 引理4.1 所有没有逆序、没有空闲时间的调度具有相同的 最大延迟. 证: 设 f 没有逆序,在 f 中具有相同完成时间的客户i1, i2, … , ik 必被连续安排. 在这k个客户中最大延迟是最后一个客 户,被延迟的时间是 k
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
9
活动安排问题
设有n个活动的集合E={1,2,…,n},其中每个活动都要求 使用同一资源,如演讲会场等,而在同一时间内只有一个 活动能使用这一资源。每个活动i都有一个要求使用该资源 的起始时间si和一个结束时间fi,且si <fi 。如果选择了活动 i,则它在半开时间区间[si, fi)内占用资源。若区间[si, fi)与 区间[sj, fj)不相交,则称活动i与活动j是相容的。也就是说, 当si≥fj或sj≥fi时,活动i与活动j相容。
3
9. 数值分析算法。如果在比赛中采用高级语言进行编 程的话,那些数值分析中常用的算法比如方程组 求解、矩阵运算、函数积分等算法就需要额外编写库 函数进行调用。 10. 图象处理算法。赛题中有一类问题与图形有关, 即使问题与图形无关,论文中也会需要图片来说明 问题,这些图形如何展示以及如何处理就是需要解决 的问题,通常使用MATLAB 进行处理。
贪心算法并不总能求得问题的整体最优解。但对 于活动安排问题,贪心算法greedySelector却总能求 得的整体最优解,即它最终所确定的相容活动集合A 的规模最大。这个结论可以用数学归纳法证明。
13
背包问题
给定n种物品和一个背包。物品i的重量是Wi, 其价值为Vi,背包的容量为C。应如何选择装 入背包的物品,使得装入背包中物品的总价值 最大?(假定物品可以分割成更小部分,亦即 物品可以部分装入)
具体算法可描述如下页:
17
float knapsack(float c,float w[], float v[],float x[]) { int n=v.length; for (int i = 0; i < n; i++) d[i] = (w[i],v[i],i); MergeSort.mergeSort(d); int i; float opt=0; for (i=0;i<n;i++) x[i]=0; for (i=0;i<n;i++) { if (d[i].w>c) break; x[d[i].i]=1; opt+=d[i].v; c-=d[i].w; } if (i<n){ x[d[i].i]=c/d[i].w; opt+=x[d[i].i]*d[i].v; } return opt; }
4
贪心算法
5
问题引入:
有下面几种面值的硬币:一元、五角、 一角、五分、一分,假设要付给顾客 2.89元的零钱,要求用最少的硬币。
6
顾名思义,贪心算法总是作出在当前看来最好的选择。 也就是说贪心算法并不从整体最优考虑,它所作出的 选择只是在某种意义上的局部最优选择。当然,希望 贪心算法得到的最终结果也是整体最优的。虽然贪心 算法不能对所有问题都得到整体最优解,但对许多问 题它能产生整体最优解。如单源最短路经问题,最小 生成树问题等。在一些情况下,即使贪心算法不能得 到整体最优解,其最终结果却是最优解的很好近似。
if (s[i]>=f[j]) {
各活动的起始时间和结 束时间存储于数组s和f
a[i]=true; j=i; count++;
中且按结束时间的非减 序排列
}
else a[i]=false;
}
return count;
}
11
活动安排问题
例:设待安排的11个活动的开始时间和结束时间按结 束时间的非减序排列如下:
10
活动安排问题
在下面所给出的解活动安排问题的贪心算法greedySelor(int s[], int f[], boolean a[])
{
int n=s.length-1;
a[1]=true;
int j=1;
int count=1; for (int i=2;i<=n;i++) {
i 1 2 3 4 5 6 7 8 9 10 11 S[i] 1 3 0 5 3 5 6 8 8 2 12 f[i] 4 5 6 7 8 9 10 11 12 13 14
12
活动安排问题
若被检查的活动i的开始时间Si小于最近选择的活动j 的结束时间fi,则不选择活动i,否则选择活动i加入集 合A中。
14
例: 有5件物品,背包的容量为100,物品的重量 和价值分别如下所示:
12345 W 10 20 30 40 50 V 20 30 66 40 60
15
这个问题有三种看似合理的选择: 1、每次选择剩余物品中价值最大的 2、每次选择剩余物品中重量最轻的 3、每次选择剩余物品中单位重量价值最高的。
2
6. 最优化理论的三大非经典算法:模拟退火算法、神 经网络算法、遗传算法。这些问题是用来解决一 些较困难的最优化问题的,对于有些问题非常有帮助, 但是算法的实现比较困难,需慎重使用。 7. 网格算法和穷举法。两者都是暴力搜索最优点的算 法,在很多竞赛题中有应用,当重点讨论模型本 身而轻视算法的时候,可以使用这种暴力方案,最好 使用一些高级语言作为编程工具。 8. 一些连续数据离散化方法。很多问题都是实际来的, 数据可以是连续的,而计算机只能处理离散的 数据,因此将其离散化后进行差分代替微分、求和代 替积分等思想是非常重要的。
16
用贪心算法解背包问题的基本步骤:
首先计算每种物品单位重量的价值Vi/Wi,然后,依贪 心选择策略,将尽可能多的单位重量价值最高的物品装 入背包。若将这种物品全部装入背包后,背包内的物品 总重量未超过C,则选择单位重量价值次高的物品并尽可 能多地装入背包。依此策略一直地进行下去,直到背包 装满为止。
7
主要知识点:
活动安排问题 背包问题 最优装载 单源最短路径 最小生成树
8
活动安排问题
活动安排问题就是要在所给的活动集合中选出最 大的相容活动子集合,是可以用贪心算法有效求解的 很好例子。该问题要求高效地安排一系列争用某一公 共资源的活动。贪心算法提供了一个简单、漂亮的方 法使得尽可能多的活动能兼容地使用公共资源。
数学建模竞赛中十类常用算法
1. 蒙特卡罗算法。该算法又称随机性模拟算法,是通 过计算机仿真来解决问题的算法,同时可以通过模拟 来检验自己模型的正确性。 2. 数据拟合、参数估计、插值等数据处理算法。比赛 中通常会遇到大量的数据需要处理,而处理数据的关 键就在于这些算法,通常使用MATLAB 作为工具。
1
3. 线性规划、整数规划、多元规划、二次规划等规划 类算法。建模竞赛大多数问题属于最优化问题,很多 时候这些问题可以用数学规划算法来描述,通常使用 Lingo 软件求解。 4. 图论算法。这类算法可以分为很多种,包括最短路、 网络流、二分图等算法,涉及到图论的问题可以用这 些方法解决。 5. 动态规划、回溯搜索、分治算法、分支定界等计算 机算法。这些算法是算法设计中比较常用的方法, 竞赛中很多场合会用到。
活动安排问题
设有n个活动的集合E={1,2,…,n},其中每个活动都要求 使用同一资源,如演讲会场等,而在同一时间内只有一个 活动能使用这一资源。每个活动i都有一个要求使用该资源 的起始时间si和一个结束时间fi,且si <fi 。如果选择了活动 i,则它在半开时间区间[si, fi)内占用资源。若区间[si, fi)与 区间[sj, fj)不相交,则称活动i与活动j是相容的。也就是说, 当si≥fj或sj≥fi时,活动i与活动j相容。
3
9. 数值分析算法。如果在比赛中采用高级语言进行编 程的话,那些数值分析中常用的算法比如方程组 求解、矩阵运算、函数积分等算法就需要额外编写库 函数进行调用。 10. 图象处理算法。赛题中有一类问题与图形有关, 即使问题与图形无关,论文中也会需要图片来说明 问题,这些图形如何展示以及如何处理就是需要解决 的问题,通常使用MATLAB 进行处理。
贪心算法并不总能求得问题的整体最优解。但对 于活动安排问题,贪心算法greedySelector却总能求 得的整体最优解,即它最终所确定的相容活动集合A 的规模最大。这个结论可以用数学归纳法证明。
13
背包问题
给定n种物品和一个背包。物品i的重量是Wi, 其价值为Vi,背包的容量为C。应如何选择装 入背包的物品,使得装入背包中物品的总价值 最大?(假定物品可以分割成更小部分,亦即 物品可以部分装入)
具体算法可描述如下页:
17
float knapsack(float c,float w[], float v[],float x[]) { int n=v.length; for (int i = 0; i < n; i++) d[i] = (w[i],v[i],i); MergeSort.mergeSort(d); int i; float opt=0; for (i=0;i<n;i++) x[i]=0; for (i=0;i<n;i++) { if (d[i].w>c) break; x[d[i].i]=1; opt+=d[i].v; c-=d[i].w; } if (i<n){ x[d[i].i]=c/d[i].w; opt+=x[d[i].i]*d[i].v; } return opt; }
4
贪心算法
5
问题引入:
有下面几种面值的硬币:一元、五角、 一角、五分、一分,假设要付给顾客 2.89元的零钱,要求用最少的硬币。
6
顾名思义,贪心算法总是作出在当前看来最好的选择。 也就是说贪心算法并不从整体最优考虑,它所作出的 选择只是在某种意义上的局部最优选择。当然,希望 贪心算法得到的最终结果也是整体最优的。虽然贪心 算法不能对所有问题都得到整体最优解,但对许多问 题它能产生整体最优解。如单源最短路经问题,最小 生成树问题等。在一些情况下,即使贪心算法不能得 到整体最优解,其最终结果却是最优解的很好近似。
if (s[i]>=f[j]) {
各活动的起始时间和结 束时间存储于数组s和f
a[i]=true; j=i; count++;
中且按结束时间的非减 序排列
}
else a[i]=false;
}
return count;
}
11
活动安排问题
例:设待安排的11个活动的开始时间和结束时间按结 束时间的非减序排列如下:
10
活动安排问题
在下面所给出的解活动安排问题的贪心算法greedySelor(int s[], int f[], boolean a[])
{
int n=s.length-1;
a[1]=true;
int j=1;
int count=1; for (int i=2;i<=n;i++) {
i 1 2 3 4 5 6 7 8 9 10 11 S[i] 1 3 0 5 3 5 6 8 8 2 12 f[i] 4 5 6 7 8 9 10 11 12 13 14
12
活动安排问题
若被检查的活动i的开始时间Si小于最近选择的活动j 的结束时间fi,则不选择活动i,否则选择活动i加入集 合A中。
14
例: 有5件物品,背包的容量为100,物品的重量 和价值分别如下所示:
12345 W 10 20 30 40 50 V 20 30 66 40 60
15
这个问题有三种看似合理的选择: 1、每次选择剩余物品中价值最大的 2、每次选择剩余物品中重量最轻的 3、每次选择剩余物品中单位重量价值最高的。
2
6. 最优化理论的三大非经典算法:模拟退火算法、神 经网络算法、遗传算法。这些问题是用来解决一 些较困难的最优化问题的,对于有些问题非常有帮助, 但是算法的实现比较困难,需慎重使用。 7. 网格算法和穷举法。两者都是暴力搜索最优点的算 法,在很多竞赛题中有应用,当重点讨论模型本 身而轻视算法的时候,可以使用这种暴力方案,最好 使用一些高级语言作为编程工具。 8. 一些连续数据离散化方法。很多问题都是实际来的, 数据可以是连续的,而计算机只能处理离散的 数据,因此将其离散化后进行差分代替微分、求和代 替积分等思想是非常重要的。
16
用贪心算法解背包问题的基本步骤:
首先计算每种物品单位重量的价值Vi/Wi,然后,依贪 心选择策略,将尽可能多的单位重量价值最高的物品装 入背包。若将这种物品全部装入背包后,背包内的物品 总重量未超过C,则选择单位重量价值次高的物品并尽可 能多地装入背包。依此策略一直地进行下去,直到背包 装满为止。
7
主要知识点:
活动安排问题 背包问题 最优装载 单源最短路径 最小生成树
8
活动安排问题
活动安排问题就是要在所给的活动集合中选出最 大的相容活动子集合,是可以用贪心算法有效求解的 很好例子。该问题要求高效地安排一系列争用某一公 共资源的活动。贪心算法提供了一个简单、漂亮的方 法使得尽可能多的活动能兼容地使用公共资源。
数学建模竞赛中十类常用算法
1. 蒙特卡罗算法。该算法又称随机性模拟算法,是通 过计算机仿真来解决问题的算法,同时可以通过模拟 来检验自己模型的正确性。 2. 数据拟合、参数估计、插值等数据处理算法。比赛 中通常会遇到大量的数据需要处理,而处理数据的关 键就在于这些算法,通常使用MATLAB 作为工具。
1
3. 线性规划、整数规划、多元规划、二次规划等规划 类算法。建模竞赛大多数问题属于最优化问题,很多 时候这些问题可以用数学规划算法来描述,通常使用 Lingo 软件求解。 4. 图论算法。这类算法可以分为很多种,包括最短路、 网络流、二分图等算法,涉及到图论的问题可以用这 些方法解决。 5. 动态规划、回溯搜索、分治算法、分支定界等计算 机算法。这些算法是算法设计中比较常用的方法, 竞赛中很多场合会用到。