题意:告诉每头奶牛指定挤奶的时间区间,每台机器只能给一头奶牛挤奶,问最少需要几台机器,并且输出每头奶牛的机器编号
思路:利用优先队列,之前看过一个题目,告诉几段工作时间,在指定时间内问最多能做几件工作,那题思路是取结束时间早的,比赛的时候以为这题也是那样,后来发现不是同一个问题额,自己代码实现不了。。。先按开始时间从早到晚排序,如果相同的话就按结束时间从早到晚排序,判断每次是否有已经挤奶完成的机器,有则使用,没有就再开始新的一台。
#include <iostream>
#include<stdio.h>
#include<string>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
#define N 50019
using namespace std;
struct Node
{
int st,en;//开始结束时间
int s,id;//当前机器和牛的编号
bool operator <(const Node &a)const
{
if(en==a.en)
return st>a.st;
return a.en<en;
}
}node[N];
priority_queue<Node>q;
int a[N];//存储奶牛使用的机器编号
bool cmp(Node a,Node b)
{
if(a.st==b.st)//如果开始时间相同,则返回结束时间早的
return a.en<b.en;
return a.st<b.st;
}
int main()
{
int n;
while(~scanf("%d",&n))
{
for(int i=1;i<=n;i++)
{
scanf("%d%d",&node[i].st,&node[i].en);
node[i].id=i;
}
sort(node+1,node+1+n,cmp);
node[0].s=1;//开始机器编号为1
node[0].en=0;
q.push(node[0]);
int num=2;//记录使用机器的数量
for(int i=1;i<=n;i++)
{
Node c=q.top();
if(node[i].st>c.en)
{
q.pop();
node[i].s=c.s;
a[node[i].id]=c.s;
q.push(node[i]);
}
else
{
node[i].s=num;
a[node[i].id]=num++;
q.push(node[i]);
}
}
printf("%d\n",num-1);
for(int i=1;i<=n;i++)
printf("%d\n",a[i]);
}
return 0;
}