acwing 111. 畜栏预定【贪心、区间分组】

有N头牛在畜栏中吃草。

每个畜栏在同一时间段只能提供给一头牛吃草,所以可能会需要多个畜栏。
给定N头牛和每头牛开始吃草的时间A以及结束吃草的时间B,每头牛在[A,B]这一时间段内都会一直吃草。
当两头牛的吃草区间存在交集时(包括端点),这两头牛不能被安排在同一个畜栏吃草。
求需要的最小畜栏数目和每头牛对应的畜栏方案。

输入格式
第1行:输入一个整数N。
第2…N+1行:第i+1行输入第i头牛的开始吃草时间A以及结束吃草时间B,数之间用空格隔开。

输出格式
第1行:输入一个整数,代表所需最小畜栏数。
第2…N+1行:第i+1行输入第i头牛被安排到的畜栏编号,编号是从1开始的 连续 整数,只要方案合法即可。

数据范围
1≤N≤50000
1≤A,B≤1000000

输入样例:
5
1 10
2 4
3 6
5 8
4 7

输出样例:
4
1
2
3
2
4

https://www.acwing.com/problem/content/description/113/

#include <iostream>
#include <algorithm>
#include <queue>
#include <stdio.h>
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
using namespace std;
const int N = 50010;
struct Node{
	int a,b,i; //i的目的是,因为后面用了sort打扰了顺序,但是输出的时候要按照牛的顺序输出畜栏
}node[N];

int tw[N],n;

struct qNode{
	int ed,t;
}qnode;

bool cmp1(Node x,Node y){
	return  x.a < y.a;
}

struct cmp2{
	bool operator () (qNode x,qNode y){
		return x.ed > y.ed;
	}
};

int main(int argc, char** argv) {
	    cin >>n;
		for(int i = 0 ; i < n ; i++)
		{
			scanf("%d %d",&node[i].a,&node[i].b);
			node[i].i=i;
		}
		sort(node,node+n,cmp1);
		priority_queue < qNode, vector <qNode> , cmp2 > q;
		for(int i = 0 ; i <n ; i++)
		{
			if(q.empty() || node[i].a <= q.top().ed )
			//小于等于,端点重合也不能抢畜栏!
			{
				qnode.ed = node[i].b;
				qnode.t = q.size();
				tw[node[i].i] = qnode.t;
				q.push(qnode);
			 }
			else
			{
				qNode temp = q.top();
				q.pop();
				qnode.ed = node[i].b ;
				qnode.t = temp.t ;
				tw[node[i].i] = qnode.t;
				q.push(qnode);
			}
		 } 
		 cout << q.size()  << endl; 
		 for( int i = 0 ; i < n ; i++)
		 {
		 	printf("%d\n",tw[i]+1);
		 }
	

	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值