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

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

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

题目描述

有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个面试到来的时间和需要面试的时间。

输出

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

样例输入

11 1 0

样例输出

1

题目  类似于 hdoj2037 今年暑假不AC~

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
struct node{
	int s, t;
}p[1200];
int cmp(node a, node b){
	return a.t < b.t;
}
int main(){
	int w;
	scanf("%d", &w);
	while(w--)
	{
		int n;
		scanf("%d", &n);
		if(n==0)
			printf("0\n");
		else{
			int sum = 0;
			int i,j,k;
			for(i = 0; i < n; i++)
			{
				scanf("%d%d", &p[i].s, &p[i].t);
				p[i].t += p[i].s;
			}	
			sort(p, p+n, cmp);
			int m = 0;
			for(i = 0; i < n; i++)
			{
				if(p[i].s > m){
					sum++;	
					m = p[i].t;
				}
			}	
			printf("%d\n", sum);
		}	
	}
	return 0;
}




你可能感兴趣的:(hpuoj 1720: 感恩节KK专场——面试难题【贪心】)