计算理论与算法分析设计:04-greedy_第1页
计算理论与算法分析设计:04-greedy_第2页
计算理论与算法分析设计:04-greedy_第3页
计算理论与算法分析设计:04-greedy_第4页
计算理论与算法分析设计:04-greedy_第5页
已阅读5页,还剩56页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

贪心法(贪婪法)

贪心算法顾名思义,贪心算法总是作出在当前看来最好的选择贪心算法并不从整体最优考虑,它所作出的选择只是在某种意义上的局部最优选择贪心算法不能对所有问题都得到整体最优解,但对许多问题它能产生整体最优解:如单源最短路径问题,最小生成树问题等在一些情况下,即使贪心算法不能得到整体最优解,其最终结果却是最优解的很好近似。2数钱

一出纳员支付一定数量的现金。假设他手

中有各种面值的纸币和硬币,要求他用最

少的货币数支付规定的现金。

例如,现有4种硬币:它们的面值分别为1

分、2分、5分和1角。要支付2角5分。首先支付2个1角硬币,然后支付一个5分

硬币,这就是贪心策略。3贪心法不一定能产生正确的答案。例如,若引进一个“1角1分”的硬币,设从如下集合{1,1,2,2,2,5,10,10,11,11}中数出25分,按贪心法,共4个硬币。但最优解仅为3个硬币。这说明贪心法得到的解只是一个可行解。4货郎担(TSP)问题设售货员要到五个城市去售货,最后再回到出发的城市。已知从一个城市到其他城市的费用,求总费用最少的路线5权为13从不同结点出发:

依贪心算法

1)结点a为起点:

2)结点b为起点:

3)结点c为起点:

4)结点d为起点:权为13权为13权为13abcd213743或者156而实际上图中最短哈密顿

回路的长度为12。即abcdaabcd2137437活动安排:问题描述有n个活动集E={1,2,…,n}使用同一资源,而同一时间内同一资源只能由一个活动使用。每个活动的使用时间为[si,fi)i=1,…,n,si为开始时间,fi为结束时间,若[si,fi)与[sj,fj)不相交称活动i和活动j是相容的,即当si≥fj或sj≥fi时。问题:选出最大的相容活动子集合。8贪心策略将各活动按结束时间排序f1≤f2≤…≤fn,先选出活动1,然后按活动编好从小到大的次序依次选择与当前活动相容的活动。注:这种策略使剩余的可安排时间极大化,以便于安排尽可能多的相容活动。

9voidActivitySelection(intn,s[],f[],boola[]){//f[]已排序,a[]记录选择的活动,即a[i]=true表示活动i已选择

a[1]=true;intj=1;for(inti=2;i<=n;i++){if(s[i]>=f[j]){a[i]=true;j=i;}elsea[i]=false;}}T(n)=O(nlogn)10找出与之相容且结束时间最早的活动活动安排:计算示例11个活动已按结束时间排序,用贪心算法求解:

i1234567891011start_timei130535688212finish_timei456789101112131401234567891011121314timea1a2a3a4a5a6a7a8a9a10a11相容活动:{a3,a9,a11},{a1,a4,a8,a11},{a2,a4,a9,a11}01234567891011121314timea1a2a3a4a5a6a7a8a9a10a1111活动安排问题由于以活动完成时间的非减序排列,所以算法greedySelector每次总是选择具有最早完成时间的相容活动加入集合A中。该算法的贪心选择的意义是使剩余的可安排时间段极大化,以便安排尽可能多的相容活动算法greedySelector的效率极高。当输入的活动已按结束时间的非减序排列,算法只需O(n)的时间安排n个活动,使最多的活动能相容地使用公共资源。如果所给出的活动未按非减序排列,可以用O(nlogn)的时间重排。12活动安排问题贪心算法并不总能求得问题的整体最优解对于活动安排问题,贪心算法greedySelector却总能求得的整体最优解,即它最终所确定的相容活动集合A的规模最大可以用数学归纳法证明13活动安排贪心算法最优化证明首先,若活动安排E={1,2,…,n}问题有一个最优解,其必包括活动1假设A是最优解,且其第一个活动为kk=1:满足k>1:设B=(A–{k})U{1}。由于f1<=fk,则若fk相容,则f1必相容,因为f1比fk先结束;故k应设为1选择活动1后,原问题就简化为找出E中所有与活动1相容的活动A为E最优解,则A’=A–{1}为E’={iE:si>=f1}的最优解假设E’的最优解为B’,则它应含有比A’更多的活动因此B’+{1}大于A’+{1},与A为最优解矛盾144.2贪心算法的基本要素对于一个具体的问题是否可用贪心算法解此问题?能否得到问题的最优解呢?从许多可以用贪心算法求解的问题中看到这类问题一般具有2个重要的性质:贪心选择性质最优子结构性质154.2贪心算法的基本要素贪心选择性质所求问题的整体最优解可以通过一系列局部最优的选择,即贪心选择来达到贪心算法可行的第一个基本要素与动态规划算法的主要区别动态规划算法通常以自底向上的方式解各子问题贪心算法则通常以自顶向下的方式进行,以迭代的方式作出相继的贪心选择,每作一次贪心选择就将所求问题简化为规模更小的子问题164.2贪心算法的基本要素最优子结构性质当一个问题的最优解包含其子问题的最优解时,称此问题具有最优子结构性质问题的最优子结构性质是该问题可用动态规划算法或贪心算法求解的关键特征174.2贪心算法的基本要素贪心算法与动态规划算法的差异 共同点:都要求问题具有最优子结构性质疑问:对于具有最优子结构的问题应该选用贪心算法还是动态规划算法?是否能用动态规划算法求解的问题也能用贪心算法求解?下面研究2个经典的组合优化问题,并以此说明贪心算法与动态规划算法的主要差别0-1背包问题背包问题184.2贪心算法的基本要素0-1背包问题:

给定n种物品和一个背包。物品i的重量是Wi,其价值为Vi,背包的容量为C。应如何选择装入背包的物品,使得装入背包中物品的总价值最大?

在选择装入背包的物品时,对每种物品i只有2种选择,即装入背包或不装入背包。不能将物品i装入背包多次,也不能只装入部分的物品i。194.2贪心算法的基本要素背包问题:

与0-1背包问题类似,所不同的是在选择物品i装入背包时,可以选择物品i的一部分,而不一定要全部装入背包,1≤i≤n。

这2类问题都具有最优子结构性质,极为相似,但背包问题可以用贪心算法求解,而0-1背包问题却不能用贪心算法求解。204.2贪心算法的基本要素用贪心算法解背包问题的基本步骤:

首先计算每种物品单位重量的价值Vi/Wi,然后,依贪心选择策略,将尽可能多的单位重量价值最高的物品装入背包。若将这种物品全部装入背包后,背包内的物品总重量未超过C,则选择单位重量价值次高的物品并尽可能多地装入背包。依此策略一直地进行下去,直到背包装满为止。21背包问题

已知一个容量大小为M重量的背包和n种物品,物品i的重量为wi,假定物品i的一部分xi放入背包会得到vixi这么大的收益,这里,0≤xi≤1,vi>0。采用怎样的装包方法才会使装入背包的物品总效益最大?例:考虑以下情况下的背包问题

n=3,M=20,(v1,v2,v3)=(25,24,15)

(w1,w2,w3)=(18,15,10)22n=3,M=20,(v1,v2,v3)=(25,24,15)

(w1,w2,w3)=(18,15,10)

1)按效益值非增次序将物品依次放入背包

(x1,x2,x3)ΣwixiΣvixi2)按物品重量的非降次序将物品依次放入背包(1,2/15,0)18+225+24*2/15=28.2(0,2/3,1)10+1015+24*2/3=3123n=3,M=20,(v1,v2,v3)=(25,24,15)

(w1,w2,w3)=(18,15,10)

3)按vi/wi的非增次序将物品依次放入背包

(x1,x2,x3)ΣwixiΣvixi

(0,1,1/2)15+524+15/2=31.5算法:背包问题的贪心算法24voidGreedyKnapsack(intn,floatM,floatv[],floatw[],floatx[]){Sort(n,v,w);//使v1/w1≥v2/w2≥…≥vn/wnfor(inti=1;i<=n;i++)x[i]=0;floatc=M;for(inti=1;i<=n;i++){if(w[i]>c)break;x[i]=1;c-=w[i];}if(i<=n)x[i]=c/w[i];}25

算法的计算时间上界为O(nlogn),主要用于排序操作。为了证明算法的正确性,还必须证明背包问题具有贪心选择性质。证明使用此贪心算法所得到的贪心解是一个最优解。证明的基本思想是:把这个贪心解与任一个最优解相比较,如果这两个解不同,就去找开始不同的第一个xi,然后设法用贪心解的这个xi去代换最优解的那个xi,并证明在分量作了代换之后其总效益与代换之前无任何损失。反复进行这种代换,直到新产生的最优解与贪心解完全一样,从而证明了贪心解是最优解。264.2贪心算法的基本要素对于0-1背包问题,贪心选择不能得到最优解它无法保证最终能将背包装满,部分闲置的背包空间使每公斤背包空间的价值降低了在考虑0-1背包问题时,应比较选择该物品和不选择该物品所导致的最终方案,然后再作出最好选择。由此就导出许多互相重叠的子问题。这正是该问题可用动态规划算法求解的一个重要特征274.3最优装载

有一批集装箱要装上一艘载重量为c的轮船。其中集装箱i的重量为wi。最优装载问题要求确定在装载体积不受限制的情况下,将尽可能多的集装箱装上轮船。假设n=8,[w1,...,w8]=[100,200,50,90,150,50,20,80],c=400。28

4.3最优装载

从剩下的货箱中,选择重量最小的货箱。这种选择次序可以保证所选的货箱总重量最小,从而可以装载更多的货箱。根据这种贪婪策略,首先选择最轻的货箱,然后选次轻的货箱,如此下去直到所有货箱均装上船或船上不能再容纳其他任何一个货箱。

29[w1,...,w8]=[100,200,50,90,150,50,20,80],c=400。

利用贪婪算法时,所考察货箱的顺序为7,3,6,8,4,1,5,2。货箱7,3,6,8,4,1的总重量为390个单位且已被装载,剩下的装载能力为10个单位,小于剩下的任何一个货箱。在这种贪婪解决算法中得到[x1,...,x8]=[1,0,1,1,0,1,1,1]且∑xi=6。304.3最优装载voidContainerLoading(intx[],floatw[],floatc,intn){Sort(w,t,n);//此时,w[i]≤w[i+1]for(inti=1;i<=n;i++)//初始化xx[i]=0;for(i=1;i<=n&&w[i]<=c;i++){x[i]=1;c-=w[i];}//

剩余容量}T(n)=O(nlogn)314.3最优装载2.贪心选择性质最优装载问题具有贪心选择性质。3.最优子结构性质

最优装载问题具有最优子结构性质。

32贪心算法性质的通用证明方法通用证明步骤首先考察问题的一个整体最优解,并尝试通过贪心选择来修改这个最优解把这个贪心解与任一个最优解相比较,如果这两个解不同,就去找开始不同的第一个xi,然后设法用贪心解的这个xi去代换最优解的那个xi,并证明在分量作了代换之后其总效益与代换之前无任何损失。反复进行这种代换,直到新产生的最优解与贪心解完全一样,从而证明贪心解是最优解。334.3最优装载问题贪心性质的证明

344.4哈夫曼编码广泛用于数据文件压缩的编码方法压缩率通常在20%~90%之间用字符在文件中出现的频率表来建立一个用0,1串表示各字符的最优表示方式出现频率高的字符较短的编码,出现频率较低的字符以较长的编码,可以大大缩短总码长354.4哈夫曼编码1、前缀码对每一个字符规定一个0,1串作为其代码,并要求任一字符的代码都不是其它字符代码的前缀。这种编码称为前缀码。消除解码的歧义364.4哈夫曼编码编码的前缀性质可以使译码方法非常简单表示最优前缀码的二叉树总是一棵完全二叉树,即树中任一结点都有2个儿子结点平均码长定义为:使平均码长达到最小的前缀码编码方案称为给定编码字符集C的最优前缀码。37

4.4哈夫曼编码2、构造哈夫曼编码哈夫曼提出构造最优前缀码的贪心算法,由此产生的编码方案称为哈夫曼编码。哈夫曼算法以自底向上的方式构造表示最优前缀码的二叉树T。算法以|C|个叶结点开始,执行|C|-1次的“合并”运算后产生最终所要求的树T。384.4哈夫曼编码编码字符集中每一字符c的频率是f(c)以f为键值的优先队列Q用在贪心选择时确定当前要合并的2棵具有最小频率的树2棵具有最小频率的树合并后产生一棵新的树,其频率为合并的2棵树的频率之和,并将新树插入优先队列Q。经过n-1次的合并后,优先队列中只剩下一棵树,即所要求的树T。O(nlogn)39Huffman编码某通讯系统只使用5种字符a、b、c、d、e,使用频率分别为0.1,0.14,0.2,0.26,0.3,利用二叉树设计不等长编码:1)构造以a、b、c、d、e为叶子的二叉树;2)将该二叉树所有左分枝标记0,所有右

分枝标记1;3)从根到叶子路径上标记作为叶子结点所

对应字符的编码;40

acbdea:000b:001c:01d:10e:115种字符a、b、c、d、e,使用频率分别为0.1,0.14,0.2,0.26,0.3414.4哈夫曼编码3、哈夫曼算法的正确性要证明哈夫曼算法的正确性,需证明(1)贪心选择性质(2)最优子结构性质424.5单源最短路径给定带权有向图G=(V,E),其中每条边的权是非负实数。另外,还给定V中的一个顶点,称为源。现在要计算从源到所有其它各顶点的最短路长度。这个问题通常称为单源最短路径问题。1、算法基本思想Dijkstra算法是单源最短路径问题的贪心算法434.5单源最短路径Dijkstra最短路:按路径长度递增的次序产生从源点v到其余各点的最短路径。设S为已求得最短路径的终点的集合,则可证明:下一条最短路径(设其终点为x),或者为有向边(v,x),或者是中间只经过S中的顶点而最后到达顶点x的路径。反证法:假设此路径上有一个顶点y不在S中,则说明存在一条终点不在S而长度比此路径短的路径。但这是不可能的。因为我们是按路径长度递增的次序来产生各最短路径的,故长度比此路径短的所有路径都已产生,它们的终点必在S中,即假设不成立。44最短路例10(v5)第1短V1V5V4V2V3V610101002050205030510v2v3v4v5v6step1503010010∞20(v4)第2短step2503020∞30(v3)第3短step34030∞35(v2)第4短step4355045(v6)第5短step545/V1/V5/V1/V3/V245例例如,对右图中的有向图,应用Dijkstra算法计算从源顶点1到其它顶点间最短路径的过程列在下页的表中。Dijkstra算法的迭代过程:迭代Sudist[2]dist[3]dist[4]dist[5]初始{1}-10/V1∞301001{1,2}26030/V11002{1,2,4}450/V4903{1,2,4,3}360/V34{1,2,4,3,5}51050306046算法的正确性和计算复杂性Dijkstra算法的正确性:(1)贪心选择性质(2)最优子结构性质计算复杂性:对于具有n个顶点和e条边的带权有向图,如果用带权邻接矩阵表示这个图,那么Dijkstra算法的主循环体需要O(n)时间。这个循环需要执行n-1次,所以完成循环需要O(n2)时间。算法的其余部分所需要时间不超过O(n2)。47小张被借调到一个新单位,图中a点是小张

的住宅,z为新单位的位置,边上的数字表

示距离,则小张到新单位的最短距离为__.a2z1292682795124311497361348最小生成树最小生成树的定义Kruskal算法Prim算法49网络的最小生成树在实际中有广泛应用。例如,在设计通信网络时,用图的顶点表示城市,用边(v,w)的权c[v][w]表示建立城市v和城市w之间的通信线路所需的费用,则最小生成树就给出了建立通信网络的最经济的方案。最小生成树50最小生成树

设G=(V,E)是一个无向连通带权图,如果G的一个子图T’是一棵包含G的所有顶点的树(G的生成树),生成树T’上各边权的总和(生成树的耗费)最小,则T’称为G的最小生成树(MST:minimumspanningtree)144187125818410909461121234212351464337139180218642704621740849867MIAPVDJFKBWIDFWLAXSFOORDBOS144187125818410909461121234212351464337139180218642704621740849867MIAPVDJFKBWIDFWLAXSFOORDBOS51Kruskal最小生成树算法

Kruskal在1956年提出了1个最小生成树算法。设G=(V,E)是一个连通带权图,V={1,2,…,n}。将图中的边按其权值由小到大排序,然后作如下的贪婪选择,由小到大顺序选取各条边,若选某边后不形成回路,则将其保留作为树的一条边;若选某边后形成回路,则将其舍弃,以后也不再考虑。如此依次进行,到选够(n-1)条边即得到最小生成树。最小生成树52例如,对于下图中的带权图各边按权值排序为:d13=1d46=2d25=3d36c4d14=

5d34=5d23=5d12=6d35=6d56=653按Kruskal算法选取边的过程如下图所示。54Kruskal最小生成树算法最小生成树//在一个具有n个顶点的网络中找棵最小生成树令E为网络中边的集合令T为所选边的集合,初始化T为空集

while(E不是空集&&T中元素个数不等于n-1){

令(u,v)为E中最小代价的边;E=E-(u,v);//从中删除该边;if((u,v)加入T中不会产生环)

将(u,v)加入T;}算法复杂度为O(n+eloge)55Prim最小生成树算法

Prim在1957

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论