news 2026/5/1 5:07:11

《P3810 【模板】三维偏序 / 陌上花开》

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《P3810 【模板】三维偏序 / 陌上花开》

题目背景

这是一道模板题,可以使用 bitset,CDQ 分治,树套树,KD-Tree 等方式解决。

题目描述

有 n 个元素,第 i 个元素有 ai​,bi​,ci​ 三个属性,设 f(i) 表示满足 aj​≤ai​ 且 bj​≤bi​ 且 cj​≤ci​ 且 j=i 的 j 的数量。

对于所有 d∈[0,n),求 f(i)=d 的数量。

输入格式

第一行两个整数 n,k,表示元素数量和最大属性值。

接下来 n 行,每行三个整数 ai​,bi​,ci​,分别表示三个属性值。

输出格式

共 n 行,第 d+1 行表示 f(i)=d 的 i 的数量。

输入输出样例

输入 #1复制

10 3 3 3 3 2 3 3 2 3 1 3 1 1 3 1 2 1 3 1 1 1 2 1 2 2 1 3 2 1 2 1

输出 #1复制

3 1 3 0 1 0 1 0 0 1

说明/提示

对于所有数据,保证 1≤n≤105,1≤ai​,bi​,ci​≤k≤2×105。

代码实现:

#include <iostream> #include <cstdio> #include <algorithm> using namespace std; const int N=1e5+10; int n,m,tn; int sz[N],res[N],cnt[N],tr[2*N]; struct nd { int x,y,z; int id; bool operator != (const nd &t) const { return (x!=t.x||y!=t.y||z!=t.z); } }inp[N],dat[N],tmp[N]; inline int lowbit(int x) { return x&(-x); } inline void upd(int x,int c) { for(int i=x;i<=m;i+=lowbit(i)) tr[i]+=c; } inline int qry(int x) { int s=0; for(int i=x;i>=1;i-=lowbit(i)) s+=tr[i]; return s; } inline void cdq(int l,int r) { if(l==r) return; int mid=(l+r)/2,p=l,q=mid+1; cdq(l,mid),cdq(mid+1,r); for(int i=l;i<=r;i++) { if((p<=mid&&dat[p].y<=dat[q].y)||q>r) upd(dat[p].z,sz[dat[p].id]),tmp[i]=dat[p++]; else res[dat[q].id]+=qry(dat[q].z),tmp[i]=dat[q++]; } for(int i=l;i<=mid;i++) upd(dat[i].z,-sz[dat[i].id]); for(int i=l;i<=r;i++) dat[i]=tmp[i]; } inline bool cmp(nd a, nd b) { if(a.x==b.x) { if(a.y==b.y) return a.z<b.z; else return a.y<b.y; } else return a.x<b.x; } int main() { scanf("%d%d",&tn,&m); for(int i=1;i<=tn;i++) scanf("%d%d%d",&inp[i].x,&inp[i].y,&inp[i].z); sort(inp+1,inp+tn+1,cmp); for(int i=1;i<=tn;i++) { if(inp[i]!=inp[i-1]) dat[++n]=inp[i],dat[n].id=n; sz[n]++; } cdq(1,n); for(int i=1;i<=n;i++) cnt[res[dat[i].id]+sz[dat[i].id]-1]+=sz[dat[i].id]; for(int i=0;i<tn;i++) printf("%d\n",cnt[i]); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/27 18:20:48

国标GB28181平台EasyGBS全面支持国密GB35114协议

在安防视频监控领域&#xff0c;“联网互通”和“安全可控”一直是两大核心需求。我们熟知的GB/T 28181协议&#xff0c;解决了不同品牌监控设备“连得上、看得见”的互联互通问题&#xff0c;但在信息安全防护上仍有提升空间。而国密GB35114协议的出现&#xff0c;恰好填补了这…

作者头像 李华
网站建设 2026/4/29 21:54:55

通过 C# 设置 Word 文档背景颜色、背景图

在 .NET 开发场景中&#xff0c;对 Word 文档进行自动化格式处理是常见需求&#xff0c;其中设置文档背景&#xff08;颜色或图片&#xff09;是提升文档视觉呈现的基础操作。Free Spire.Doc for .NET 作为一款免费的 Word 文档操作组件&#xff0c;无需依赖 Microsoft Office …

作者头像 李华
网站建设 2026/4/25 18:15:20

springboot基于安卓速到外卖app-开题报告

目录 项目背景与意义技术选型与优势核心功能模块创新点与难点预期成果进度计划 项目技术支持可定制开发之功能亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作 项目背景与意义 随着移动互联网的普及&#xff0c;外卖行业呈现爆发式增长…

作者头像 李华
网站建设 2026/4/16 15:35:38

收藏!2026年程序员薪资天花板:转岗大模型,月薪11万+不是梦

最近&#xff0c;一张标注着**月薪11万**的程序员工资条&#xff0c;在CSDN、GitHub等技术社区彻底炸开了锅&#xff0c;评论区瞬间被“酸哭”“求转岗攻略”“后悔没早学大模型”的留言刷屏。 深入了解才知道&#xff0c;这张薪资条的主人&#xff0c;原本是一名深耕3年的传统…

作者头像 李华