贪心算法----区间选点

题目:

给定 N 个闭区间 [ai,bi],请你在数轴上选择尽量少的点,使得每个区间内至少包含一个选出的点。输出选择的点的最小数量。位于区间端点上的点也算作区间内。
输入样例:

3
-1 1
2 4
3 5

思路

解题思路:先将每个区间按右端点从小到大排序,然后每次枚举每个区间,当某个区间内已经取了点时,直接跳过即可,否则取每个区间最右端的端点。

代码

#include <iostream>
#include <algorithm>
using namespace std;
const int N = 100010;
int n;
// 定义结构体range,重载小于号按右端点排序
// 结构体中保存每个区间的左端点l与右端点r
// range[0].l表示 输入的第1个区间的左端点,右端点的表示同理
struct Range
{
    int l, r;
    bool operator< (const Range &W)const
    {
        return r < W.r;
    }
}range[N];

int main()
{
    scanf("%d", &n);
    for (int i = 0; i < n; i ++ ) 
        scanf("%d%d", &range[i].l, &range[i].r);
        // 按右端点排序
    sort(range, range + n);
    // res表示当前点的数量,ed表示上一个区间的右端点
    int res = 0, ed = -2e9;
    for (int i = 0; i < n; i ++ )
        // 如果当前区间的左端点>上一个区间的右端点
        // 更新ed,res+1
        if (ed < range[i].l)
        {
            res ++ ;
            ed = range[i].r;
        }

    printf("%d\n", res);

    return 0;
}

理解 为什么使用重载

我们在这里重载小于号的目的,是为了使用STL函数sort。
sort()排序是基于大小顺序,从小到大来调整序列顺序。
如有一个数组:

int ans[] = {4 8 2 6};
sort(a,a+4) ; // 输出a得到 2 4 6 8

但是对于我们自定义的结构体Range,我们想让它们按右端点进行从小到大的排序,能够直接使用sort函数吗?

显然是不可能的,因为这个结构体中有左端点,有右端点,而sort函数不知道按哪个属性来进行排序。
这时就需要对小于号 < 进行重载,相当于给sort函数指定,就按我给定的return表达式进行排序。即:

   bool operator< (const Range &W)const
    {
        return r < W.r;
    }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值