HPU 1720: 感恩节KK专场——面试难题【贪心】

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

时间限制: 1 Sec   内存限制: 128 MB
提交: 303   解决: 44
[ 提交][ 状态][ 讨论版]

题目描述

有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

提示

来源

KK

AC-code:

#include<cstdio>
#include<algorithm>
using namespace std;
struct node
{
	int st,e;
}s[1005];
bool cmp(node a,node b)
{
	return a.e<b.e;
}
int main()
{
	int t,n,i,a,ans,b;
	scanf("%d",&t);
	while(t--)
	{
		scanf("%d",&n);
		if(n==0)
		{
			printf("0\n");
			continue;
		 } 
		for(i=0;i<n;i++)
		{
			scanf("%d%d",&s[i].st,&b);
			s[i].e=s[i].st+b;
		}
		sort(s,s+n,cmp);
		a=s[0].e;
		ans=1;
		for(i=1;i<n;i++)
			if(s[i].st>a)
			{
				ans++;
				a=s[i].e;
			}
		printf("%d\n",ans);
	}
	return 0;
}


你可能感兴趣的:(贪心,HPU)