活动选择问题
Time Limit: 1000MS Memory limit: 65536K
题目描述
sdut 大学生艺术中心每天都有n个活动申请举办,但是为了举办更多的活动,必须要放弃一些活动,求出每天最多能举办多少活动。
输入
输入包括多组输入,每组输入第一行为申请的活动数n,从第2行到n+1行,每行两个数,是每个活动的开始时间b,结束时间e;
输出
输出每天最多能举办的活动数。
示例输入
12 15 20 15 19 8 18 10 15 4 14 6 12 5 10 2 9 3 8 0 7 3 4 1 3
示例输出
5
提示
#include<stdio.h>
#include<algorithm>
using namespace std;
struct sa
{
int start,end;
}data[1007];
int cmp(const sa &a,const sa &b)
{
return a.end<b.end;
}
int main()
{
int m;
while(scanf("%d",&m)!=EOF)
{
for(int i=0;i<m;i++)
scanf("%d%d",&data[i].start,&data[i].end);
sort(data,data+m,cmp);
sa temp=data[0];
int count=1;
for(int j=0;j<m;j++)
{
if(temp.end<=data[j].start)
{
count++;
temp=data[j];
}
}
printf("%d\n",count);
}
return 0;
}