区间分组

该问题旨在将区间按照无交集的要求分成最小数量的组。首先对区间按左端点进行升序排序,然后遍历区间,利用优先队列管理右端点,确保新加入的区间不与已有区间重叠。当新区间左端点大于当前最大右端点时,可放入同一组;否则,需新开辟一组。最后,优先队列的大小即为最小组数。
摘要由CSDN通过智能技术生成

题目

题目链接:906.区间分组

给定 N 个闭区间 [ai,bi],请你将这些区间分成若干组,使得每组内部的区间两两之间(包括端点)没有交集,并使得组数尽可能小。

输出最小组数。

输入格式

第一行包含整数 N,表示区间数。

接下来 N 行,每行包含两个整数 ai,bi,表示一个区间的两个端点。

输出格式

输出一个整数,表示最小组数。

数据范围

1≤N≤10^5,
−10^9≤ai≤bi≤10^9

输入样例:
3
-1 1
2 4
3 5
输出样例:
2

 

AC代码 

// 贪心思想:
// 将区间按左端点从小到大排序,排序后从前往后遍历,有以下两种情况:
// 1.当区间的左端点比之前区间右端点大时,它俩不重合,可以放一组,并将该组的右端点更新为较大一个
// 2.当区间的左端点比之前区间右端点小或等于时,它俩重合,不能放一起,需要开辟新的组


#include<bits/stdc++.h>
using namespace std;

const int N = 1e5 + 10;

int n;
struct Range{
    int l, r;
    
    bool operator< (const Range &w)const{
        return l < w.l;
    }
}range[N];

int main()
{
    cin >> n;
    for(int i = 0; i < n; i++)
        cin >> range[i].l >> range[i].r;
        
    sort(range, range + n);
    
    priority_queue<int, vector<int>, greater<int>> heap;    //使用堆进行管理
    for(int i =0; i < n; i++)
    {
        auto r = range[i];
        if(heap.empty() || heap.top() >= r.l)heap.push(r.r);//第2种情况
        else{                                               //非2即1
            heap.pop();
            heap.push(r.r);
        }
    }
    
    cout << heap.size() << endl;
        
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果你想按照某个字段的值的区间分组,可以使用 MySQL 中的 CASE 表达式和 GROUP BY 语句来实现。以下是一个示例: 假设我们有一个表名为 scores,其中包含学生姓名和成绩两列,我们想要按照成绩的区间分组,并统计每个区间内的学生人数。 首先,我们可以使用 CASE 表达式来将成绩分成不同的区间,例如: ``` SELECT CASE WHEN score >= 90 THEN 'A' WHEN score >= 80 THEN 'B' WHEN score >= 70 THEN 'C' WHEN score >= 60 THEN 'D' ELSE 'F' END AS grade, COUNT(*) AS count FROM scores GROUP BY grade; ``` 这个查询会将成绩分成五个区间,并统计每个区间内的学生人数。 注意,我们在 SELECT 语句中使用了 AS 关键字来为 CASE 表达式创建一个别名,这样我们就可以在 GROUP BY 语句中使用这个别名来分组。 另外,COUNT(*) 函数用于计算每个分组中的行数,也就是每个区间内的学生人数。 ### 回答2: MySQL按区间分组可以使用CASE WHEN语句和GROUP BY子句来实现。 假设我们有一个名为"sales"的表,包含了销售数据的信息,其中有一个列"amount"表示销售额。 如果我们希望按照销售额分成三个区间进行分组,可以使用CASE WHEN语句来实现。语法如下: SELECT CASE WHEN amount < 1000 THEN '0-1000' WHEN amount >= 1000 AND amount < 5000 THEN '1000-5000' WHEN amount >= 5000 THEN '5000以上' END AS sales_range, SUM(amount) AS total_amount FROM sales GROUP BY sales_range; 上述查询将会按照销售额区间进行分组,并计算每个区间的总销售额。 例如,如果销售额在0到1000之间,它将被归为'0-1000'区间,如果销售额在1000到5000之间,它将被归为'1000-5000'区间,如果销售额大于等于5000,它将被归为'5000以上'的区间。 最后,我们使用GROUP BY子句将结果按照sales_range进行分组,并计算每个区间的总销售额。 ### 回答3: MySQL 按区间分组,可以使用CASE WHEN语句和GROUP BY子句来实现。 首先,假设有一个包含学生成绩的表格,其中有学生名字和分数两列。我们想按照分数的区间进行分组并计算每个区间内的学生数量。 可以使用CASE WHEN语句来判断每个分数属于哪个区间,然后使用GROUP BY子句按照区间分组。具体步骤如下: ``` SELECT CASE WHEN score >= 90 THEN '90-100' -- 区间判断条件 WHEN score >= 80 THEN '80-89' WHEN score >= 70 THEN '70-79' WHEN score >= 60 THEN '60-69' ELSE '0-59' END AS score_range, -- 将区间结果设为新列 COUNT(*) AS student_count -- 计算每个区间内的学生数量 FROM scores GROUP BY score_range -- 按区间分组 ``` 在上述示例中,首先使用CASE WHEN语句根据分数的不同判断所属的区间(90-100,80-89,70-79,60-69,0-59),然后将区间结果设为新列score_range。 然后,使用GROUP BY子句按照score_range进行分组。最后,使用COUNT(*)统计每个区间内的学生数量。 这样即可实现按区间分组的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值