活动选择
问题描述
学校在最近几天有 nn(n≤100n≤100)个活动,这些活动都需要使用学校的大礼堂,在同一时间,礼堂只能被一个活动使。由于有些活动时间上有冲突,学校办公室人员只好让一些活动放弃使用礼堂而使用其他教室。
现在给出 nn 个活动使用礼堂的起始时间 beginibegini 和结束时间 endiendi (beginibegini << endiendi),请你帮助办公室人员安排一些活动来使用礼堂,要求安排的活动尽量多。请问最多可以安排多少活动?
请注意,开始时间和结束时间均指的是某个小时的 00 分 00 秒,如:33 55,指的是 3:003:00~5:005:00 ,因此33 55和55 99这两个时间段不算冲突的时间段。
输入
第一行一个整数 nn (n≤100n≤100);
接下来的 nn 行,每行两个整数,第一个 beginibegini ,第二个是 endiendi (beginibegini << endiendi ≤≤ 3276732767);
输出
输出最多能安排的活动数;
样例
输入
复制
11 3 5 1 4 12 14 8 12 0 6 8 11 6 10 5 7 3 8 5 9 2 13
输出
复制
4
编辑代码
#include<iostream>
#include<algorithm>
using namespace std;
const int MAX=100;
struct hd{
int fffff;
int eeeeeeeeeeeee;
}a[MAX];
bool cmp(hd a,hd b){
return a.eeeeeeeeeeeee < b.eeeeeeeeeeeee;
}
int main()
{
int n;
cin>>n;
for(int i=0;i<n;i++)
cin>>a[i].fffff>>a[i].eeeeeeeeeeeee;
sort(a,a+n,cmp);
int num=1;
int rrrrrrrr=0;
for(int i=0;i<n;i++){
if(a[rrrrrrrr].eeeeeeeeeeeee <= a[i].fffff){
num++;
rrrrrrrr=i;
}
}
cout<<num<<endl;
return 0;
}