news 2026/4/18 9:55:20

《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/15 9:13:02

Java:float 和 double

在 Java 中&#xff0c;float 和 double 都是用于表示浮点数的数据类型&#xff0c;但它们在精度、内存占用和适用场景上有所不同。 1. ‌精度与位数‌‌float‌ 是单精度浮点数&#xff0c;占用 4 个字节&#xff08;32 位&#xff09;&#xff0c;提供大约 6 到 7 位十进制有…

作者头像 李华
网站建设 2026/4/18 8:39:12

罗技G系列游戏外设全解析及G304X入门游戏鼠标推荐

一、罗技G系列&#xff1a;游戏外设的核心战略布局罗技作为全球外设巨头&#xff0c;其产品体系清晰分为两大核心系列&#xff1a;G系列&#xff08;游戏系列&#xff09;与办公系列。其中&#xff0c;G系列以“专业电竞”为核心定位&#xff0c;聚焦游戏场景的高性能需求&…

作者头像 李华
网站建设 2026/4/18 8:47:34

雷鸟创新背着10亿闯三关

拿了资本的钱&#xff0c;还需要蹚出自己的路。作者|安德鲁编辑|古廿作为智能眼镜领域的垂直玩家&#xff0c;刚拿到10亿元融资的雷鸟创新&#xff0c;正在进入一个并不轻松的阶段。甜蜜在于&#xff0c;行业窗口终于被打开。过去几年持续押注智能眼镜的雷鸟&#xff0c;开始真…

作者头像 李华
网站建设 2026/4/18 8:41:59

大数据领域数据运营的数据分析可视化

深入浅出&#xff1a;大数据领域数据运营的数据分析可视化 摘要/引言 在大数据时代&#xff0c;数据运营已成为企业决策的关键驱动力。然而&#xff0c;海量的数据若不经过有效处理和呈现&#xff0c;就如同深埋于矿山中的宝藏&#xff0c;难以发挥其价值。数据分析可视化作为…

作者头像 李华
网站建设 2026/4/18 7:40:29

电脑技术员、网管必备AI工具 :iFixPC(蓝伏豚爱维PC)

在现代企业中&#xff0c;IT 运维团队和电脑技术员每天都要面对大量的系统维护、故障排查和自动化任务。传统的运维方式往往需要记忆复杂的命令、参数和脚本语法&#xff0c;不仅耗时&#xff0c;还容易出错。随着企业规模的扩大&#xff0c;运维效率的提升变得尤为关键。今天&…

作者头像 李华