NYOJ-14:会场安排问题

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/wingrez/article/details/81949676

NYOJ-14:会场安排问题

来源:http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=14

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

参考资料:

相似题目:

题目

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

输入

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

输出

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

输入样例

输出样例

题目大意

解题思路

参考代码

#include<stdio.h>
#include<algorithm>
#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;
}

猜你喜欢

转载自blog.csdn.net/wingrez/article/details/81949676