【晴问算法】入门篇—贪心算法—区间不相交问题

题目描述

给定n个开区间,从中选择尽可能多的开区间,使得这些开区间两两没有交集。

输入描述

输出描述

输出一个整数,表示最多选择的开区间个数。

样例1
输入

4

1 3

2 4

3 5

6 7

输出

3

解释

最多选择(1,3)、(3,5)、(6,7)三个区间,它们互相没有交集。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int MAXN = 100;
int a[MAXN];
struct qj{
	int x;//左端点
	int y;//右端点
};//定义区间结构体,依次输入区间的左右端点
bool cmp(qj a, qj b){//qj类型的a和b
	return a.y < b.y;//返回右端点较小的区间
}
int main(){
	struct qj a[MAXN];
	int n;
	cin >> n;
	for(int i=0;i<n;i++){
		scanf("%d %d",&a[i].x,&a[i].y);
	}
	sort(a,a+n,cmp);//按照右端点小的顺序
	int last = a[0].y;//第一个区间的左端点
	int count = 1;//第一个区间一定能被选中
	for(int i=1;i<n;i++){//从第二个区间开始判断
		if(a[i].x >= last){//如果当前区间的左端点大于等于上一个区间的右端点
			count++;//则不会交集,个数加1
			last = a[i].y;//更新当前的右端点
		}
	}
	printf("%d",count);
	
	
	
	return 0;
}
相关推荐
柯慕灵2 分钟前
轻量推荐算法框架 Torch-rechub——基于PyTorch
pytorch·算法·推荐算法
源代码•宸2 分钟前
goframe框架签到系统项目开发(用户认证中间件、实现Refresh-token接口)
数据库·经验分享·后端·算法·中间件·跨域·refreshtoken
YGGP5 分钟前
【Golang】LeetCode 300. 最长递增子序列
算法·leetcode
隐语SecretFlow5 分钟前
隐语SML0.1.0版本发布!SPU开源机器学习Python算法库
python·算法·机器学习
zdd567897 分钟前
GIN索引原理
运维·算法·postgresql
byzh_rc14 分钟前
[算法设计与分析-从入门到入土] 查找&合并&排序&复杂度&平摊分析
数据结构·数据库·人工智能·算法·机器学习·支持向量机·排序算法
谎言西西里6 小时前
LeetCode 热题100 --- 双指针专区
算法
leo__5209 小时前
基于两步成像算法的聚束模式SAR MATLAB实现
开发语言·算法·matlab
前端小白在前进10 小时前
力扣刷题:在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
某林21211 小时前
基于SLAM Toolbox的移动机器人激光建图算法原理与工程实现
stm32·嵌入式硬件·算法·slam