- 1、本文档共39页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
15 贪心算法
算法导论
基于人性,理想永远只属于少数人。可是,
少数人的理想经常会推动时代,为多数人
谋取福利。
15 贪心算法
Greedy Algorithms
• 贪心算法总是作出在当前看来最好的选择。也就
是说贪心算法并不从整体最优考虑,它所作出的
选择只是在某种意义上的局部最优选择。
• 当然,希望贪心算法得到的最终结果也是整体最
优的。虽然贪心算法不能对所有问题都得到整体
最优解,但对许多问题它能产生整体最优解。如
单源最短路经问题,最小生成树问题等。在一些
情况下,即使贪心算法不能得到整体最优解,其
最终结果却是最优解的很好近似。
15.1 活动安排问题
• 活动安排问题就是要在所给的活动集合中
选出最大的相容活动子集合,是可以用贪
心算法有效求解的很好例子。该问题要求
高效地安排一系列争用某一公共资源的活
动。贪心算法提供了一个简单、漂亮的方
法使得尽可能多的活动能兼容地使用公共
资源。
• 设有n个活动的集合E={1,2,…,n},其中每个活
动都要求使用同一资源,如教室等,而在同一
时间内只有一个活动能使用这一资源。每个活
动i都有一个要求使用该资源的起始时间s 和一
i
个结束时间f ,且s f 。如果选择了活动i,则
i i i
它在半开时间区间[s ,f ) 内占用资源。
i i
• 若区间[s ,f )与区间[s ,f )不相交,则称活动i与
i i j j
活动j是相容的。也就是说,当s ≥f 或s ≥f 时,
i j j i
活动i与活动j相容。
• 例如:讨论下面的活动集合E,其中各个
活动已按结束时间的单调递增的顺序进行
了排序。
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
• 解决方法:选择一个活动ai,使其具有最
早的结束时间。
void GreedySelector(int n, int s[], int 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;
}
}
• 由于输入的活动以其完成时间的非减序排
列,所以算法GreedySelector每次总是选
择具有最早完成时间的相容活动加入集合
A 中。直观上,按这种方法选择相容活动
为未安排活动留下尽可能多的时间。也就
是说,该算法的贪心选择的意义是使剩余
的可安排时间段极大化,以便安排尽可能
多的相容活动。
• 算法GreedySelector的效率极高。当输入
的活动已按结束时间的非减序排列,算法
只需O(n)的时间安排n个活动,使最多的
活动能相容地使用公共资源。如果所给出
的活动未按非减序排列,可以用O(nlogn)
的时间重排。
• 算法greedySelector
的计算过程如左图所
示。图中每行相应于
算法的一次迭代。阴
影长条表示的活动是
已选入集合A的活动
文档评论(0)