[AcWing] 908. 最大不相交区间数量(C++实现)贪心---区间问题例题

1. 题目

在这里插入图片描述

2. 读题(需要重点注意的东西)

思路:
AcWing 905. 区间选点问题一模一样,甚至代码都是一样的。解法在此不再赘述。

贪心 -----> 每次在当前的选法中,选择能选的情况中的最优解

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


代码实现思路:

3. 解法

---------------------------------------------------解法---------------------------------------------------

#include <iostream>
#include <algorithm>

using namespace std;

const int N = 100010; // 最多有10w个区间

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);
    // 读入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 (range[i].l > ed)
        {
            res ++ ;
            ed = range[i].r;
        }

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

    return 0;
}

可能存在的问题(所有问题的位置都在上述代码中标注了出来)

4. 可能有帮助的前置习题

5. 所用到的数据结构与算法思想

  • 贪心

6. 总结

贪心思想、区间问题的例题,理解思想并自行推导出代码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Cloudeeeee

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

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

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

打赏作者

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

抵扣说明:

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

余额充值