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 ...
随机推荐
- vs2012 提示 未能正确加载 "Visual C++ Language Manager Package" 包 的解决办法
1.点击vs2012菜单栏 工具-> Visual Studio 命令提示 打开命令窗口 2.输入命令 "devenv /Setup" 3.重新打开vs2012
- java 导出Excel 大数据量,自己经验总结!
出处: http://lyjilu.iteye.com/ 分析导出实现代码,XLSX支持: /** * 生成<span style="white-space: normal; back ...
- 小米盒子连接老式电脑显示器(VGA接口)
家里闲置一台老式显示器,只有VGA接口,无HDMI高清接口; 小米盒子上有三个输出接口: 一个HDMI高清接口:HDMI接口输出的有音频信号和视频信号,现在买的电视机一般都有HDMI高清接口: 一个A ...
- 防止SQL注入问题
-----解决方案--------------------------------------------------------过滤URL中的一些特殊字符,动态SQL语句使用PrepareState ...
- Jquery动画方法 jquery.animate()
目前在学习Oracle数据库,由于刚接触,学校让练习练习HTML内容,就想起了老师以前提起过的animate方法 animate是jquery的一个方法,这个方法主要功能是能实现比较平滑的动态效果,所 ...
- [转载] 理解 rto
原文: http://mp.weixin.qq.com/s?__biz=MzAxNjM3MDkyOQ==&mid=204656491&idx=1&sn=5046aa16eee0 ...
- [转载] Go语言并发之美
原文: http://qing.blog.sina.com.cn/2294942122/88ca09aa33002ele.html 简介 多核处理器越来越普及,那有没有一种简单的办 ...
- maven项目搭建
一.Maven简介 Maven是基于Java平台的项目构建(mvn clean install).依赖管理(中央仓库,Nexus)和项目信息管理的项目管理工具. Maven是基于项目对象模型(POM) ...
- jQuery UI 实例 - 对话框(Dialog)(zhuan)
http://www.runoob.com/jqueryui/example-dialog.html ************************************************* ...
- OpenGL的GLUT初始化函数[转]
OpenGL的GLUT初始化函数 void glutInit(int* argc,char** argv) 初始化GLUT库.对应main函数的形式应是:int main(int argc,char* ...