POJ-2828-Buy Tickets

编程技术  /  houtizong 发布于 3年前   164

POJ-2828-Buy Tickets

http://poj.org/problem?id=2828

线段树,逆序插入

#include<iostream>#include<cstdio>#include<cstring>#include<cstdlib>using namespace std;#define N 200010struct cam{int x,y;int num;}list[N*8];int pos[N],value[N],ans[N];int n;void build(int k,int x,int y)  //用线段树存储区间内还有多少位子没有被占{list[k].x=x;list[k].y=y;list[k].num=(y-x+1);if(x==y)return;int mid;mid=(x+y)/2;build(k<<1,x,mid);build(k<<1|1,mid+1,y);}void find(int k,int pos,int value){list[k].num--;if(list[k].x==list[k].y){ans[list[k].x]=value;return;}if(list[k<<1].num>=pos)find(k<<1,pos,value);elsefind(k<<1|1,pos-list[k<<1].num,value);}int main(){int i;while(scanf("%d",&n)!=EOF){for(i=1;i<=n;i++)scanf("%d%d",&pos[i],&value[i]);build(1,1,n);for(i=n;i>=1;i--)find(1,pos[i]+1,value[i]);for(i=1;i<=n;i++){if(i==n)printf("%d\n",ans[i]);elseprintf("%d ",ans[i]);}}return 0;}


请勿发布不友善或者负能量的内容。与人为善,比聪明更重要!

留言需要登陆哦

技术博客集 - 网站简介:
前后端技术:
后端基于Hyperf2.1框架开发,前端使用Bootstrap可视化布局系统生成

网站主要作用:
1.编程技术分享及讨论交流,内置聊天系统;
2.测试交流框架问题,比如:Hyperf、Laravel、TP、beego;
3.本站数据是基于大数据采集等爬虫技术为基础助力分享知识,如有侵权请发邮件到站长邮箱,站长会尽快处理;
4.站长邮箱:[email protected];

      订阅博客周刊 去订阅

文章归档

文章标签

友情链接

Auther ·HouTiZong
侯体宗的博客
© 2020 zongscan.com
版权所有ICP证 : 粤ICP备20027696号
PHP交流群 也可以扫右边的二维码
侯体宗的博客