贪心算法-区间调度问题解之证明

一、贪心算法 

  定义:一个算法是贪心算法,如果它是通过一些小的步骤来一个求解,并且在每一步根据局部情况选择一个决定,使得某些主要的指标得到优化。

二、区间调度问题

  1. 问题:我们有一组需求{1,2,3,......,N},第i个需求与一个开始时间s(i),结束时间f(i)相对应。如果没有两个需求在时间上重叠,我们就说需求的子集是相容的。

  2. 目标:寻找一个最大的相容子集O.

  3. 算法:

    初始令R是所有需求的集合,设A为空

      While ( |R| > 0 )  

        选择一个最早结束的需求

        把i加入到A中

        在R中删除所有与i不相容的需求

      End

      返回集合A作为被接受的需求的集合

    算法规则:该贪心算法的规则是,每一步选择一个最早结束的需求,尽快释放资源。

  4. 证明算法的正确性:

  假设O是最优解,由于最优解可能有多个,所以,我们只需要证明|A|=|O|,既证明集合A与集合O包含的需求个数相等。显然,A,O都是相容的,既A,O中的任意两个需要都不会重叠。

  算法思想:该证明主要是想找出这样一种认识,我们的贪心算法“领先”于这个最优解O. 我们把贪心算法构造的部分解与最优解O初始的一段进行比较,并且证明贪心算法以一步接一步的方式做的更好。

  假设,A = { i1,i2,......,ik }, O = { j1,j2,......,jm } ,既我们要证明k=m;同时&

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
区间调度问题是指在一些活动中选择一些互不冲突的活动,使得能够完成的活动数最多贪心算法是一种常用的解决该问题的方法。下面是该算法证明过程: 假设存在最优解S,其中包含n个活动。我们将这些活动按照结束时间的先后顺序排列,即e1≤e2≤...≤en。我们用A1表示S中结束时间最早的活动,用Ak表示S中结束时间最晚的活动。我们假设Ak不在贪心算法得到的结果集中,而是选择了另一个活动Aj。因为Ak结束时间最晚,所以Aj的结束时间一定不晚于Ak,即ej≥ek。而根据贪心算法,Ak是在所有结束时间不早于ej的活动中结束时间最晚的,所以Ak的结束时间不晚于Aj,即ek≥ej。因此,ej=ek,即Ak和Aj的结束时间相同。但是,由于Ak是S中结束时间最晚的活动,所以Aj不可能在S中,与假设矛盾。因此,Ak一定在贪心算法得到的结果集中。 接下来,我们用数学归纳法证明贪心算法得到的结果集是最优解。假设贪心算法得到的结果集为S,其中包含m个活动。我们将这些活动按照结束时间的先后顺序排列,即e1≤e2≤...≤em。我们用B1表示S中结束时间最早的活动,用Bk表示S中结束时间最晚的活动。我们假设Bk在最优解中的位置是i,即Bk是最优解中的第i个活动。因为Bk是S中结束时间最晚的活动,所以在最优解中,前i-1个活动的结束时间一定不晚于ek,即ei-1≥ek。而根据贪心算法,Bk是在所有结束时间不早于ei-1的活动中结束时间最晚的,所以Bk的结束时间不早于最优解中前i-1个活动的结束时间,即ej≥ei-1。因此,ei-1≥ek≤ej,即Bk和Bi-1的结束时间相同。但是,由于Bk是最优解中结束时间最晚的活动,所以Bi-1不可能在最优解中的位置在i之后,即Bi-1在最优解中的位置一定在i之前。因此,我们可以将Bi-1替换成Bk,得到一个包含m-1个活动的最优解。根据数学归纳法,贪心算法得到的结果集是最优解。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jackson61

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值