【贪心】AcWing 110. 防晒算法正确性证明

题目描述

有 C 头奶牛进行日光浴,第 i 头奶牛需要 m i n S P F [ i ] minSPF[i] minSPF[i] m a x S P F [ i ] maxSPF[i] maxSPF[i] 单位强度之间的阳光。

每头奶牛在日光浴前必须涂防晒霜,防晒霜有 L L L 种,涂上第 i i i 种之后,身体接收到的阳光强度就会稳定为 S P F [ i ] SPF[i] SPF[i],第 i i i 种防晒霜有 c o v e r [ i ] cover[i] cover[i] 瓶。

求最多可以满足多少头奶牛进行日光浴。

输入格式

第一行输入整数 C C C L L L

接下来的 C C C 行,按次序每行输入一头牛的 m i n S P F minSPF minSPF m a x S P F maxSPF maxSPF 值,即第 i 行输入 m i n S P F [ i ] minSPF[i] minSPF[i] m a x S P F [ i ] maxSPF[i] maxSPF[i]

再接下来的 L L L 行,按次序每行输入一种防晒霜的 S P F SPF SPF c o v e r cover cover 值,即第 i i i 行输入 S P F [ i ] SPF[i] SPF[i] c o v e r [ i ] cover[i] cover[i]

每行的数据之间用空格隔开。

输出格式

输出一个整数,代表最多可以满足奶牛日光浴的奶牛数目。

数据范围

1 ≤ C , L ≤ 2500 1≤C,L≤2500 1C,L2500
1 ≤ m i n S P F ≤ m a x S P F ≤ 1000 1≤minSPF≤maxSPF≤1000 1minSPFmaxSPF1000
1 ≤ S P F ≤ 1000 1≤SPF≤1000 1SPF1000

输入样例:
3 2
3 10
2 5
1 5
6 2
4 1
输出样例:
2


Solution

有一种贪心算法:按 m i n S P F minSPF minSPF 从大到小考虑每头奶牛,选取当前未被选取的 S P F SPF SPF 最大的防晒霜。
证明其正确性:
可以发现此题是一个二分图的最大匹配问题,于是我们可以证明按照贪心算法得到的匹配是最大匹配,即该匹配不存在增广路。
考虑反证法,设奶牛编号为 c i c_i ci ,防晒霜为 s i s_i si
若存在一条增广路,取其中最短的一条 s 1 → c 1 → s 2 → c 2 → ⋯ → s n → c n s_1\rightarrow c_1\rightarrow s_2\rightarrow c_2\rightarrow\cdots\rightarrow s_n\rightarrow c_n s1c1s2c2sncn ,则:

引理 : c 1 , c 2 , . . . , c n c_1,c_2,...,c_n c1,c2,...,cn m i n S P F minSPF minSPF 递增
证明:
若存在 c i + 1 c_{i+1} ci+1 使得 m i n S P F [ c i + 1 ] < m i n S P F [ c i ] minSPF[c_{i+1}]<minSPF[c_i] minSPF[ci+1]<minSPF[ci] ,则可将 s i − 1 s_{i-1} si1 直接连向 c i + 1 c_{i+1} ci+1
此时存在一条更短的增广路,矛盾,故引理1成立。

因此,由于增广路最后一条边必须是非匹配边,因此 c n c_n cn 没有匹配点,但由于引理可知 c n c_n cn 在排序后位于 c 1 ∼ c n − 1 c_1\sim c_{n-1} c1cn1 之前,又由于贪心算法, c n c_n cn 会与 s n s_n sn 匹配,矛盾,因此贪心算法正确。


证明参考自 yxc 大佬

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
贪心算法是一种常用的解决问题的策略,它在每一步选择中都采取当前状态下最优的选择,以期望最终能够得到全局最优解。然而,贪心算法正确性并不总是显然的,需要进行证明。 要证明贪心算法正确性,通常需要使用数学归纳法或反证法等数学方法。下面以一个简单的例子来说明贪心算法正确性证明过程。 假设有一个背包问题,要求在给定的一组物品中选择一些放入背包中,使得背包的总价值最大,但不能超过背包的容量。每个物品有两个属性:重量和价值。 贪心算法的思路是每次选择当前剩余物品中价值最高的物品放入背包中,直到背包无法再放入物品为止。 证明贪心算法正确性可以分为两个步骤: 1. 证明贪心选择性:即证明每一步选择都是局部最优解。假设在某一步选择中,存在一个更优的选择,使得选择该物品能够得到更大的总价值。然而,由于贪心算法的策略是选择当前剩余物品中价值最高的物品,所以不存在比当前选择更优的选择,因此贪心选择性成立。 2. 证明最优子结构性质:即证明通过贪心选择得到的局部最优解能够得到全局最优解。假设存在一个最优解,其中包含了一个非贪心选择的物品。然而,我们可以将这个最优解中的非贪心选择替换为贪心选择,得到一个更优的解,与最优解的假设相矛盾。因此,通过贪心选择得到的局部最优解能够得到全局最优解,最优子结构性质成立。 综上所述,贪心算法正确性得到证明

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值