300864: CF164E. Polycarpus and Tasks

Memory Limit:256 MB Time Limit:3 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Polycarpus and Tasks

题目描述

Polycarpus has many tasks. Each task is characterized by three integers $ l_{i} $ , $ r_{i} $ and $ t_{i} $ . Three integers $ (l_{i},r_{i},t_{i}) $ mean that to perform task $ i $ , one needs to choose an integer $ s_{i} $ $ (l_{i}<=s_{i}; s_{i}+t_{i}-1<=r_{i}) $ , then the task will be carried out continuously for $ t_{i} $ units of time, starting at time $ s_{i} $ and up to time $ s_{i}+t_{i}-1 $ , inclusive. In other words, a task is performed for a continuous period of time lasting $ t_{i} $ , should be started no earlier than $ l_{i} $ , and completed no later than $ r_{i} $ . Polycarpus's tasks have a surprising property: for any task $ j,k $ (with $ j&lt;k $ ) $ l_{j}&lt;l_{k} $ and $ r_{j}&lt;r_{k} $ . Let's suppose there is an ordered set of tasks $ A $ , containing $ |A| $ tasks. We'll assume that $ a_{j}=(l_{j},r_{j},t_{j}) $ $ (1<=j<=|A|) $ . Also, we'll assume that the tasks are ordered by increasing $ l_{j} $ with the increase in number. Let's consider the following recursive function $ f $ , whose argument is an ordered set of tasks $ A $ , and the result is an integer. The function $ f(A) $ is defined by the greedy algorithm, which is described below in a pseudo-language of programming. - Step 1. ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF164E/505672ebb2b2b965326774e11bdb5318ba7faecb.png), $ ans=0 $ . - Step 2. We consider all tasks in the order of increasing of their numbers in the set $ A $ . Lets define the current task counter $ i=0 $ . - Step 3. Consider the next task: $ i=i+1 $ . If $ i&gt;|A| $ fulfilled, then go to the 8 step. - Step 4. If you can get the task done starting at time $ s_{i} $ = max $ (ans+1,l_{i}) $ , then do the task $ i $ : $ s_{i} $ = max( $ ans+1 $ , $ l_{i} $ ), $ ans=s_{i}+t_{i}-1 $ , ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF164E/d2234314ce27181704f05522f3cbe0bb4c2084f6.png). Go to the next task (step 3). - Step 5. Otherwise, find such task ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF164E/db7c19304472a3497fd497a6f1e2760996659e37.png), that first, task $ a_{i} $ can be done at time $ s_{i} $ = max![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF164E/d857492755e7baa46eb71131dba20b0df2735eda.png), and secondly, the value of ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF164E/e2b4f2ae14b40555edd964dcebdcd214e3d92a26.png) is positive and takes the maximum value among all $ b_{k} $ that satisfy the first condition. If you can choose multiple tasks as $ b_{k} $ , choose the one with the maximum number in set $ A $ . - Step 6. If you managed to choose task $ b_{k} $ , then ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF164E/d1831216ca74c7c20f5ce96b3cd78426f390c87c.png), ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF164E/8e57d31c10d27acc9143b9238807ed05e31fe78c.png). Go to the next task (step 3). - Step 7. If you didn't manage to choose task $ b_{k} $ , then skip task $ i $ . Go to the next task (step 3). - Step 8. Return $ ans $ as a result of executing $ f(A) $ . Polycarpus got entangled in all these formulas and definitions, so he asked you to simulate the execution of the function $ f $ , calculate the value of $ f(A) $ .

输入输出格式

输入格式


The first line of the input contains a single integer $ n $ ( $ 1<=n<=10^{5} $ ) — the number of tasks in set $ A $ . Then $ n $ lines describe the tasks. The $ i $ -th line contains three space-separated integers $ l_{i} $ , $ r_{i} $ , $ t_{i} $ ( $ 1<=l_{i}<=r_{i}<=10^{9} $ , $ 1<=t_{i}<=r_{i}-l_{i}+1 $ ) — the description of the $ i $ -th task. It is guaranteed that for any tasks $ j,k $ (considering that $ j&lt;k $ ) the following is true: $ l_{j}&lt;l_{k} $ and $ r_{j}&lt;r_{k} $ .

输出格式


For each task $ i $ print a single integer — the result of processing task $ i $ on the $ i $ -th iteration of the cycle (step 3) in function $ f(A) $ . In the $ i $ -th line print: - 0 — if you managed to add task $ i $ on step 4. - -1 — if you didn't manage to add or replace task $ i $ (step 7). - $ res_{i} $ ( $ 1<=res_{i}<=n $ ) — if you managed to replace the task (step 6): $ res_{i} $ equals the task number (in set $ A $ ), that should be chosen as $ b_{k} $ and replaced by task $ a_{i} $ .

输入输出样例

输入样例 #1

5
1 8 5
2 9 3
3 10 3
8 11 4
11 12 2

输出样例 #1

0 0 1 0 -1 

输入样例 #2

13
1 8 5
2 9 4
3 10 1
4 11 3
8 12 5
9 13 5
10 14 5
11 15 1
12 16 1
13 17 1
14 18 3
15 19 3
16 20 2

输出样例 #2

0 0 0 2 -1 -1 0 0 0 0 7 0 12 

Input

加入题单

算法标签: