15 贪心算法.pdf

  1. 1、本文档共39页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

yan698698 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档