Buy Tickets
Time Limit: 4000MS   Memory Limit: 65536K
Total Submissions: 17416   Accepted: 8646

Description

Railway tickets were difficult to buy around the Lunar New Year in China, so we must get up early and join a long queue…

The Lunar New Year was approaching, but unluckily the Little Cat still had schedules going here and there. Now, he had to travel by train to Mianyang, Sichuan Province for the winter camp selection of the national team of Olympiad in Informatics.

It was one o’clock a.m. and dark outside. Chill wind from the northwest did not scare off the people in the queue. The cold night gave the Little Cat a shiver. Why not find a problem to think about? That was none the less better than freezing to death!

People kept jumping the queue. Since it was too dark around, such moves would not be discovered even by the people adjacent to the queue-jumpers. “If every person in the queue is assigned an integral value and all the information about those who have jumped the queue and where they stand after queue-jumping is given, can I find out the final order of people in the queue?” Thought the Little Cat.

Input

There will be several test cases in the input. Each test case consists of N + 1 lines where N (1 ≤ N ≤ 200,000) is given in the first line of the test case. The next N lines contain the pairs of values Posi and Vali in the increasing order of i (1 ≤ iN). For each i, the ranges and meanings of Posi and Vali are as follows:

  • Posi ∈ [0, i − 1] — The i-th person came to the queue and stood right behind the Posi-th person in the queue. The booking office was considered the 0th person and the person at the front of the queue was considered the first person in the queue.
  • Vali ∈ [0, 32767] — The i-th person was assigned the value Vali.

There no blank lines between test cases. Proceed to the end of input.

Output

For each test cases, output a single line of space-separated integers which are the values of people in the order they stand in the queue.

Sample Input

4
0 77
1 51
1 33
2 69
4
0 20523
1 19243
1 3890
0 31492

Sample Output

77 33 69 51
31492 20523 3890 19243

Hint

The figure below shows how the Little Cat found out the final order of people in the queue described in the first test case of the sample input

思路:线段树。

其实就是找第K大的数,被这题坑了好多时间,本来开始咋都想不通。本来打算放弃的。

下面说一下:Posi ∈ [0, i − 1]这个条件很关键。我们从最后一个开始选取,最后一个是很容易定的,因为它就是当前所有数的第aa[i].x+1大的位置上,可以把他看成第aa[i].x+1大的数,

那么当最后一个选完后,倒数第二个就可以看成最后一个了,那么倒数第二个就是当前剩余位置中排序第aa[i-1].x+1的位置上,然后这样选取到最后就行了。其中选取的过程用线段树维护就行。复杂度N*log(n)*log(n);

  1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<math.h>
5 #include<stdlib.h>
6 #include<string.h>
7 using namespace std;
8 int tree[5*200000];
9 int id[200005];
10 typedef struct pp
11 {
12 int x;
13 int y;
14 } ss;
15 ss num[200005];
16 int id1[200005];
17 int ask(int l,int r,int k,int ans);
18 void build(int l,int r,int k);
19 void up(int k);
20 int main(void)
21 {
22 int i,j,k,p,q;
23 while(scanf("%d",&k)!=EOF)
24 { memset(tree,0,sizeof(tree));
25 memset(id1,0,sizeof(id1));
26 for(i=0; i<k; i++)
27 {
28 scanf("%d %d",&num[i].x,&num[i].y);
29 num[i].x+=1;
30 }
31 build(0,k-1,0);
32 for(i=k-1; i>=0; i--)
33 {
34 int er=ask(0,k-1,0,num[i].x);
35 id1[er]=num[i].y;
36 }
37 printf("%d",id1[0]);
38 for(i=1; i<k; i++)
39 printf(" %d",id1[i]);
40 printf("\n");
41 }
42 return 0;
43 }
44 void build(int l,int r,int k)
45 {
46 if(l==r)
47 {
48 tree[k]=1;
49 id[l]=k;
50 return ;
51 }
52 else
53 {
54 build(l,(l+r)/2,2*k+1);
55 build((l+r)/2+1,r,2*k+2);
56 tree[k]=tree[2*k+1]+tree[2*k+2];
57 }
58 }
59 void up(int k)
60 {
61 tree[k]=0;
62 if(k==0)return ;
63 else
64 {
65 int cc=k;
66 cc=(cc-1)/2;
67 while(cc>=0)
68 {
69 tree[cc]=tree[2*cc+1]+tree[2*cc+2];
70 if(cc==0)
71 return ;
72 cc=(cc-1)/2;
73 }
74 }
75 }
76 int ask(int l,int r,int k,int ans)
77 {
78 if(ans==tree[k])
79 {
80 int c=id[r];
81 if(tree[c]==1)
82 {
83 up(c);
84 return r;
85 }
86 else
87 {
88 if(tree[2*k+1]<ans)
89 {
90 return ask((l+r)/2+1,r,2*k+2,ans-tree[2*k+1]);
91 }
92 else if(tree[2*k+1]==ans)
93 {
94 return ask(l,(l+r)/2,2*k+1,ans);
95 }
96 }
97 }
98 else if(ans<tree[k])
99 {
100 if(tree[2*k+1]>=ans)
101 {
102 return ask(l,(l+r)/2,2*k+1,ans);
103 }
104 else if(tree[2*k+1]<ans)
105 {
106 return ask((l+r)/2+1,r,2*k+2,ans-tree[2*k+1]);
107 }
108 }
109 }

Buy Tickets(poj2828)的更多相关文章

  1. 【poj2828】Buy Tickets 线段树 插队问题

    [poj2828]Buy Tickets Description Railway tickets were difficult to buy around the Lunar New Year in ...

  2. [POJ2828] Buy Tickets(待续)

    [POJ2828] Buy Tickets(待续) 题目大意:多组测试,每组给出\(n\)条信息\((a,b)\),表示\(b\)前面有\(a\)个人,顺序靠后的信息优先级高 Solution.1 由 ...

  3. POJ2828 Buy Tickets[树状数组第k小值 倒序]

    Buy Tickets Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 19012   Accepted: 9442 Desc ...

  4. poj-----(2828)Buy Tickets(线段树单点更新)

    Buy Tickets Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 12930   Accepted: 6412 Desc ...

  5. POJ2828 Buy Tickets 【线段树】+【单点更新】+【逆序】

    Buy Tickets Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 12296   Accepted: 6071 Desc ...

  6. poj2828 Buy Tickets (线段树 插队问题)

    Buy Tickets Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 22097   Accepted: 10834 Des ...

  7. poj-2828 Buy Tickets(经典线段树)

    /* Buy Tickets Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 10207 Accepted: 4919 Descr ...

  8. POJ2828 Buy Tickets [树状数组,二分答案]

    题目传送门 Buy Tickets Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 22611   Accepted: 110 ...

  9. POJ2828 Buy Tickets 树状数组

    Description Railway tickets were difficult to buy around the Lunar New Year in China, so we must get ...

随机推荐

  1. Oracle中如何自定义类型

    一:Oracle中的类型有很多种,主要可以分为以下几类:1.字符串类型.如:char.nchar.varchar2.nvarchar2.2.数值类型.如:int.number(p,s).integer ...

  2. Java程序逻辑控制

    程序逻辑控制 1.Java程序结构与逻辑控制 在Java中程序有三种结构:顺序结构.分支结构.循环结构 1.1 Java分支结构 分支结构:进行逻辑判断,当满足某些条件时才会执行某些语句. 1.if语 ...

  3. 【Linux】【Basis】文件系统

    FHS:Filesystem Hierarchy Standard Web site: https://wiki.linuxfoundation.org/lsb/fhs http://www.path ...

  4. 【Linux】【Shell】【text】awk

    基本用法:gawk [options] 'program' FILE ...             program: PATTERN{ACTION STATEMENTS}               ...

  5. 分布式事务之TCC事务模型

    一.引言 在上篇文章<老生常谈--利用消息队列处理分布式事务>一文中留了一个坑,今天来填坑.如下图所示 如果服务A和服务B之间是同步调用,比如服务C需要按流程调服务A和服务B,服务A和服务 ...

  6. MySQL数据库行转列

    一.数据源如下所示 二.对应SQL语句如下所示 -- 行转列 SELECT t1.`产品名称`, SUM(CASE t1.`日期` WHEN '2019-11-11' THEN t1.`数量` ELS ...

  7. 安装Java1.8教程图解

    在服务器上配置Java环境 第一步: 因为我们系统是centOS7 64位的,所以我下载的是最新版本的jdk X64位的 因为阿里云服务器事先就安装好了ssh,我们可以用xsell连上去,我把下载好的 ...

  8. 解放生产力「GitHub 热点速览 v.21.51」

    作者:HelloGitHub-小鱼干 解放生产力一直都是我们共同追求的目标,能在摸鱼的空闲把赚了.而大部分好用的工具便能很好地解放我们的生产力,比如本周特推 RedisJSON 不用对 JSON 做哈 ...

  9. LuoguP7715 「EZEC-10」Shape 题解

    Content 有一个 \(n\times m\) 的网格,网格上的格子被涂成了白色或者黑色. 设两个点 \((x_1,y_1)\) 和 \((x_2,y_2)\),如果以下三个条件均满足: \(1\ ...

  10. CF1291A Even But Not Even 题解

    Content 有 \(t\) 组数据,每组数据给定一个整数 \(n\),接着给出一个长度为 \(n\) 的数字串.请从中删除一些数,使得剩下的数字串不是偶数,但是其和为偶数,或者不存在这样的方案. ...