0
点赞
收藏
分享

微信扫一扫

hpuoj 1720: 感恩节KK专场——面试难题 (贪心)


1720: 感恩节KK专场——面试难题

时间限制: 1 Sec  内存限制: 128 MB

提交: 300 

解决: 43

提交][状态][讨论版]


题目描述


有n个人要来面试学生会XX部门,要求面试过程中任意两个面试者之间的时间不能有重叠。已知n个面试者到来的时间和需要面试的时间,问最多可以面试多少个人。该部门的XX是KK的好友,现在他来找KK帮忙。但是KK很忙,请你帮帮KK吧。 时间重叠如[1, 3] [2, 4]或者[1, 3][3, 4]。


输入


给定一个整数t,表示有t(t<=100)组测试数据。每组测试数据有一个整数n(0<=n<=1000),接下来每行有两个整数S[i],T[i],表示第i个面试到来的时间和需要面试的时间。


输出


每行输出一个整数,表示最多可以面试的人数。


样例输入


1 1 1 0


样例输出



1

 

#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
struct zz
{
	int l;
	int r;
}q[1010];
int cmp(zz a,zz b)
{
	if(a.r==b.r)
		return a.l<b.l;
	return a.r<b.r;
}
int main()
{
	int t,n,x;
	int i,j;
	scanf("%d",&t);
	while(t--)
	{
		scanf("%d",&n);
		if(n==0)     //这块很坑,WA的想哭。。。 
			printf("0\n");
		else
		{
			for(i=0;i<n;i++)
			{
				scanf("%d%d",&q[i].l,&x);
				q[i].r=q[i].l+x;
			}
			sort(q,q+n,cmp);
			int cnt=1;
			int kk=q[0].r;
			for(i=1;i<n;i++)
			{
				if(q[i].l>kk)
				{
					cnt++;
					kk=q[i].r;
				}
			}
			printf("%d\n",cnt);
		}
	}
	return 0;
}

 

 

 

举报

相关推荐

0 条评论