poj-----(2828)Buy Tickets(线段树单点更新)
| Time Limit: 4000MS | Memory Limit: 65536K | |
| Total Submissions: 12930 | Accepted: 6412 |
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 ≤ i ≤ N). 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.

Source
#include<cstdio>
#include<cstring>
const int maxn=;
struct node
{
int lef,rig,ps; //ps-->在前方有多少个空位
int val;
int mid(){
return lef+((rig-lef)>>);
}
};
struct sac
{
int pos,val;
};
sac sav[maxn];
node reg[maxn<<];
int ans[maxn];
int cnt;
void Build(int left,int right,int pos)
{
reg[pos]=(node){left,right,,};
if(left==right) return ;
int mid=reg[pos].mid();
Build(left,mid,pos<<);
Build(mid+,right,pos<<|);
reg[pos].ps=reg[pos<<].ps+reg[pos<<|].ps;
} void Update(int ps,int val ,int pos)
{
if(reg[pos].lef==reg[pos].rig)
{
reg[pos].ps=;
reg[pos].val=val;
return ;
}
int mid=reg[pos].mid();
if(reg[pos<<].ps>ps)
Update(ps,val,pos<<);
else Update(ps-reg[pos<<].ps,val,pos<<|);
reg[pos].ps=reg[pos<<].ps+reg[pos<<|].ps;
return ;
}
void Query(int pos)
{
if(reg[pos].lef==reg[pos].rig)
{
if(cnt==)
printf("%d",reg[pos].val);
else printf(" %d",reg[pos].val);
cnt++;
return ;
}
int mid=reg[pos].mid();
Query(pos<<);
Query(pos<<|);
return ;
}
int main()
{
int n;
while(scanf("%d",&n)!=EOF)
{
cnt=;
Build(,n,);
for(int i=;i<n;i++)
scanf("%d%d",&sav[i].pos,&sav[i].val);
for(int i=n-;i>=;i--)
Update(sav[i].pos,sav[i].val,);
Query();
puts("");
}
return ;
}
优化代码:
#include<cstdio>
#include<cstring>
const int maxn=;
struct node
{
int lef,rig,ps; //ps-->在前方有多少个空位
int mid(){
return lef+((rig-lef)>>);
}
};
struct sac
{
int pos,val;
};
sac sav[maxn];
node reg[maxn<<];
int ans[maxn];
void Build(int left,int right,int pos)
{
reg[pos]=(node){left,right,};
if(left==right) return ;
int mid=reg[pos].mid();
Build(left,mid,pos<<);
Build(mid+,right,pos<<|);
reg[pos].ps=reg[pos<<].ps+reg[pos<<|].ps;
} void Update(int ps,int val ,int pos)
{
if(reg[pos].lef==reg[pos].rig)
{
reg[pos].ps=;
ans[reg[pos].lef]=val;
return ;
}
int mid=reg[pos].mid();
if(reg[pos<<].ps>ps)
Update(ps,val,pos<<);
else Update(ps-reg[pos<<].ps,val,pos<<|);
reg[pos].ps=reg[pos<<].ps+reg[pos<<|].ps;
return ;
}
int main()
{
int n;
while(scanf("%d",&n)!=EOF)
{
Build(,n,);
for(int i=;i<n;i++)
scanf("%d%d",&sav[i].pos,&sav[i].val);
for(int i=n-;i>=;i--)
Update(sav[i].pos,sav[i].val,);
printf("%d",ans[]);
for(int i=;i<=n;i++)
printf(" %d",ans[i]);
puts("");
}
return ;
}
poj-----(2828)Buy Tickets(线段树单点更新)的更多相关文章
- POJ 2828 Buy Tickets(线段树单点)
https://vjudge.net/problem/POJ-2828 题目意思:有n个数,进行n次操作,每次操作有两个数pos, ans.pos的意思是把ans放到第pos 位置的后面,pos后面的 ...
- POJ - 2828 Buy Tickets (段树单点更新)
Description Railway tickets were difficult to buy around the Lunar New Year in China, so we must get ...
- poj 2828 Buy Tickets (线段树(排队插入后输出序列))
http://poj.org/problem?id=2828 Buy Tickets Time Limit: 4000MS Memory Limit: 65536K Total Submissio ...
- POJ 2828 Buy Tickets (线段树 or 树状数组+二分)
题目链接:http://poj.org/problem?id=2828 题意就是给你n个人,然后每个人按顺序插队,问你最终的顺序是怎么样的. 反过来做就很容易了,从最后一个人开始推,最后一个人位置很容 ...
- POJ 2828 Buy Tickets 线段树 倒序插入 节点空位预留(思路巧妙)
Buy Tickets Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 19725 Accepted: 9756 Desc ...
- POJ 2828 Buy Tickets(线段树·插队)
题意 n个人排队 每一个人都有个属性值 依次输入n个pos[i] val[i] 表示第i个人直接插到当前第pos[i]个人后面 他的属性值为val[i] 要求最后依次输出队中各个人的属性 ...
- POJ 2828 Buy Tickets | 线段树的喵用
题意: 给你n次插队操作,每次两个数,pos,w,意为在pos后插入一个权值为w的数; 最后输出1~n的权值 题解: 首先可以发现,最后一次插入的位置是准确的位置 所以这个就变成了若干个子问题, 所以 ...
- poj 2828 Buy Tickets (线段树)
题目:http://poj.org/problem?id=2828 题意:有n个人插队,给定插队的先后顺序和插在哪个位置还有每个人的val,求插队结束后队伍各位置的val. 线段树里比较简单的题目了, ...
- poj 2892---Tunnel Warfare(线段树单点更新、区间合并)
题目链接 Description During the War of Resistance Against Japan, tunnel warfare was carried out extensiv ...
随机推荐
- 【转载】C++内存分配
原文:C++内存分配 内存泄露相信对C++程序员来说都不陌生.解决内存泄露的方案多种多样,大部分方案以追踪检测为主,这种方法实现起来容易,使用方便,也比较安全. 首先我们要确定这个模块的主要功能: 能 ...
- Writing On-Error Trigger In Oracle Forms
Suppose you want to handle an error in oracle forms and want to display custom error message for tha ...
- CUBRID学习笔记 14 删除主键错误
发生这样的问题.其实和别的数据库基本原因差不多. 就是外键冲突. 看看有没有外键引用这个表的主键. 然后删除外键. 就可以了 SELECT class_name FROM db_index WHER ...
- linux配置IP地址
1. ifconfig命令临时配置IP地址 ifconfig命令:查看与配置网络状态命令 如: ifconfig eht0 192.168.0.200 netmask 255.255.255.0 # ...
- CSS笔记(八)表格
参考:http://www.w3school.com.cn/css/css_table.asp 实例: <html> <head> <style type="t ...
- 【转】移动端input输入placeholder垂直不居中
在移动端编写input输入框时候,为了输入文字与输入框垂直居中,一般情况下,会将input的line-height的高度等于height.但在移动端输入的时候会发现,虽然输入内容确实是垂直居中了,但是 ...
- 使用ultramon调整任务栏高度
取消锁定,调整任务栏的高度为一行图标的高度,然后再锁定即可.为啥程序没有默认设置?
- mysql 占用的内存大小
1.mysql执行查询计划,key_len表示索引使用的字节数,这个字节数和三个条件有关.mysql> create table t1(v1 char(10));Query OK, 0 rows ...
- Android手机分辨率基础知识(DPI,DIP计算)二
dp = dip : device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA.HVGA和QVGA 推荐使用这个,不 ...
- LA 5135 Mining Your Own Business
求出 bcc 后再……根据大白书上的思路即可. 然后我用的是自定义的 stack 类模板: #include<cstdio> #include<cstring> #includ ...