NYOJ - 14:会场安排问题

会场安排问题

来源:NYOJ

标签:区间问题,贪心算法

参考资料:

相似题目:

题目

学校的小礼堂每天都会有许多活动,有时间这些活动的计划时间会发生冲突,需要选择出一些活动进行举办。小刘的工作就是安排学校小礼堂的活动,每个时间最多安排一个活动。现在小刘有一些活动计划的时间表,他想尽可能的安排更多的活动,请问他该如何安排。

输入

第一行是一个整型数m(m<100)表示共有m组测试数据。
每组测试数据的第一行是一个整数n(1 < n < 10000)表示该测试数据共有n个活动。
随后的n行,每行有两个正整数Bi,Ei(0 <= Bi,Ei < 10000),分别表示第i个活动的起始与结束时间(Bi<=Ei)

输出

对于每一组输入,输出最多能够安排的活动数量。
每组的输出占一行

输入样例

2
2
1 10
10 11
3
1 10
10 11
11 20

输出样例

1
2

参考代码

#include
#include
#define MAXN 10005
using namespace std;
struct Interval{
	int a;
	int b;
}interval[MAXN];

bool cmp(Interval x, Interval y){
	return x.b<y.b;
}

int main(){
	int m;
	scanf("%d",&m);
	while(m--){
		int n;
		scanf("%d",&n);
		for(int i=0;i<n;i++){
			scanf("%d%d",&interval[i].a,&interval[i].b);
		} 
		sort(interval,interval+n,cmp);
		int cnt=0;
		int start=0;
		int j=0;
		while(j<n){
			if(interval[j].a>=start){
				cnt++;
				start=interval[j].b+1;
			}
			j++;
		}
		printf("%d\n",cnt);
	}
	return 0;
}

你可能感兴趣的:(【记录】算法题解)