POJ2828 Buy Tickets
2022/1/11 23:07:27
本文主要是介绍POJ2828 Buy Tickets,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
考虑如果顺序模拟会T,注意到最后一个元素一定在它确定的位置,考虑从后往前放,找第k个空位,完美解决这题;
1 #include<iostream> 2 #include<cstdio> 3 #define ls (x<<1) 4 #define rs (x<<1|1) 5 using namespace std; 6 const int N=2e5+5; 7 int sum[N<<2],p[N],v[N],ans[N],n; 8 9 void update(int x) 10 { 11 sum[x]=sum[ls]+sum[rs]; 12 } 13 void build(int l,int r,int x) 14 { 15 if(l==r) 16 { 17 sum[x]=1; 18 return ; 19 } 20 int mid=(l+r)>>1; 21 build(l,mid,ls); 22 build(mid+1,r,rs); 23 update(x); 24 } 25 void modify(int l,int r,int x,int val,int k) 26 { 27 if(l==r) 28 { 29 sum[x]=0; 30 ans[l]=val; 31 return; 32 } 33 int mid=(l+r)>>1; 34 if(sum[ls]>=k)modify(l,mid,ls,val,k); 35 else modify(mid+1,r,rs,val,k-sum[ls]); 36 update(x); 37 } 38 int main() 39 { 40 while(~scanf("%d",&n)) 41 { 42 for(int i=1;i<=n;i++)scanf("%d%d",&p[i],&v[i]); 43 build(1,n,1); 44 for(int i=n;i;i--) modify(1,n,1,v[i],p[i]+1); 45 for(int i=1;i<=n;i++)printf("%d%c",ans[i],(i<n)?' ':'\n'); 46 } 47 return 0; 48 }
这篇关于POJ2828 Buy Tickets的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享