前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Code Forces 644B Processing Queries

Code Forces 644B Processing Queries

作者头像
ShenduCC
发布2018-04-26 16:18:42
7440
发布2018-04-26 16:18:42
举报
文章被收录于专栏:算法修养

B. Processing Queries time limit per test5 seconds memory limit per test256 megabytes inputstandard input outputstandard output In this problem you have to simulate the workflow of one-thread server. There are n queries to process, the i-th will be received at moment ti and needs to be processed for di units of time. All ti are guaranteed to be distinct.

When a query appears server may react in three possible ways:

If server is free and query queue is empty, then server immediately starts to process this query. If server is busy and there are less than b queries in the queue, then new query is added to the end of the queue. If server is busy and there are already b queries pending in the queue, then new query is just rejected and will never be processed. As soon as server finished to process some query, it picks new one from the queue (if it’s not empty, of course). If a new query comes at some moment x, and the server finishes to process another query at exactly the same moment, we consider that first query is picked from the queue and only then new query appears.

For each query find the moment when the server will finish to process it or print -1 if this query will be rejected.

Input The first line of the input contains two integers n and b (1 ≤ n, b ≤ 200 000) — the number of queries and the maximum possible size of the query queue.

Then follow n lines with queries descriptions (in chronological order). Each description consists of two integers ti and di (1 ≤ ti, di ≤ 109), where ti is the moment of time when the i-th query appears and di is the time server needs to process it. It is guaranteed that ti - 1 < ti for all i > 1.

Output Print the sequence of n integers e1, e2, …, en, where ei is the moment the server will finish to process the i-th query (queries are numbered in the order they appear in the input) or  - 1 if the corresponding query will be rejected.

Examples input 5 1 2 9 4 8 10 9 15 2 19 1 output 11 19 -1 21 22 input 4 1 2 8 4 8 10 9 15 2 output 10 18 27 -1

代码语言:javascript
复制
#include <iostream>
#include <string.h>
#include <algorithm>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <queue>

using namespace std;
#define MAX 200000
struct Node
{
    int id;
    long long int st;
    long long int time;
}a[MAX+5];
int cmp(Node a,Node b)
{
    return a.st<b.st;
}
queue<Node> q;
long long int ans[MAX+5];
int n,b;
int main()
{
    scanf("%d%d",&n,&b);
    for(int i=1;i<=n;i++)
    {
        scanf("%lld%lld",&a[i].st,&a[i].time);
        a[i].id=i;
    }
    sort(a+1,a+n+1,cmp);
    int i=2;
    long long int now=a[1].st+a[1].time;
    ans[1]=now;
    while(1)
    {
        if(i>n&&q.size()==0)
            break;
        while(i<=n)
        {
            if(a[i].st>=now)
                break;
            if(q.size()>=b)
                ans[a[i++].id]=-1;
            else
            {
                q.push(a[i++]);
            }
        }
        if(q.size()==0)
        {now=a[i].st+a[i].time;ans[i]=now;i++;continue;}
        Node term=q.front();
        q.pop();
        now+=term.time;
        ans[term.id]=now;
    }
    for(int i=1;i<=n;i++)
    {
        if(i==n)
            printf("%lld\n",ans[i]);
        else
            printf("%lld ",ans[i]);
    }
    return 0;
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-04-16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档