选点问题

本文探讨了在数轴上覆盖闭区间的问题,提出了通过排序和贪心策略选取最少点来满足每个区间的覆盖需求的方法。具体步骤包括按区间右端点升序排序,并从最后一个区间开始选择点作为满足条件的点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

类似的问题:活动安排问题区间覆盖问题

数轴上有n个闭区间[ai, bi]。取尽量少的点,使得每个区间内都至少有一个点(不同区间内含的点可以是同一个)。

如果区间i内已经有一个点被取到,我们称此区间已经被满足。我们先讨论区间包含的情况。由于小区间被满足时大区间一定也被满足。所以在区间包含的情况下,大区间不需要考虑。
把所有区间按b从小到大排序(b相同时a从大到小排序),则需要考虑的区间的a值也是从小到大排好序的(其他区间都不需要考虑)。第一个区间应该取哪一个点呢?

我们的贪心策略是:取最后一个。



如果不是取最后一个,比如说灰色点,那么把它移动到最后一个点后被满足的区间增加了,而且原先被满足的区间现在一定被满足。不难看出,这样的贪心策略是正确的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值