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的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-09CMS内容管理系统是什么?如何选择适合你的平台?
- 2025-01-08CCPM如何缩短项目周期并降低风险?
- 2025-01-08Omnivore 替代品 Readeck 安装与使用教程
- 2025-01-07Cursor 收费太贵?3分钟教你接入超低价 DeepSeek-V3,代码质量逼近 Claude 3.5
- 2025-01-06PingCAP 连续两年入选 Gartner 云数据库管理系统魔力象限“荣誉提及”
- 2025-01-05Easysearch 可搜索快照功能,看这篇就够了
- 2025-01-04BOT+EPC模式在基础设施项目中的应用与优势
- 2025-01-03用LangChain构建会检索和搜索的智能聊天机器人指南
- 2025-01-03图像文字理解,OCR、大模型还是多模态模型?PalliGema2在QLoRA技术上的微调与应用
- 2025-01-03混合搜索:用LanceDB实现语义和关键词结合的搜索技术(应用于实际项目)