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 ...
随机推荐
- Socket重叠IO
1.为什么到现在才弄懂这个 不知道这个Socket重叠IO这种模型是不是socket IO完成端口的基础,不过我感觉,学习一下这个再去学习socket IO完成端口是比较有好处的. 这个Scoket重 ...
- 别名alias
alias #查看已设置的别名 alias 别名='原命令' #暂时设定别名(重启失效):alias ls='ls --color=never' unalias 别名 #删除别名 设置别名永久生效 ...
- TreeView控件
public partial class WebForm1 : System.Web.UI.Page { DataSet dsTreeView = new DataSet(); protected v ...
- 《易货》Alpha版本测试报告
一.测试计划 功能需求编号 功能需求名称 功能需求描述 测试计划 1 用户注册 每一个想要发布商品或者需要购买商品的用户都需要注册一个账号 √ 2 用户登录 已经拥有账号的用户登录 √ 3 密码修改 ...
- AFNetworking请求中含有中文时程序崩溃
出现error: Assertion failure in -[AFHTTPRequestSerializer requestWithMethod:URLString:parameters:error ...
- LINUX一切皆文件
只要用过linux的筒子,或者保守点说接触到一些linux思想的同志肯定听说过这样一句话,在linux下,“一切皆是文件”! 不错,今天walfred将在快速上手linux设备驱动这一块,谈谈linu ...
- Python学习(10)元组
目录 Python 元组 访问元组 修改元组 删除元组 元组运算符 元组索引,截取 无关闭分隔符 元组内置函数 Python 元组 Python的元组与列表类似,不同之处在于元组的元素不能修改. 元组 ...
- mysql复制的配置
# 78服务器 server-id=78 # 从哪个数开始 auto_increment_offset=1 # 每次增加多少 auto_increment_increment=2 log-bin=m ...
- ORACLE数据库DBMS_JOB的创建与使用
http://my.oschina.net/u/2309120/blog/371437 创建 DBMS_JOB 使用以下语句: VARIABLE jobno number;begin DBMS_JOB ...
- Android App组件之ListFragment -- 说明和示例
Android App组件之ListFragment -- 说明和示例 1 ListFragement介绍 ListFragment继承于Fragment.因此它具有Fragment的特性,能够作为a ...