news 2026/5/28 16:18:52

《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/5/28 15:45:59

PingApi接口开发平台4.0发布

PingApi 是一款 API 接口开发平台&#xff0c;企业级接口管理、SQL2API 平台。支持动态数据源、动态 SQL 和标签&#xff0c; 支持接入&#xff08;mysql、oracle、达梦、TiDB、hive、es 和hbase&#xff09;等 SQL 或 NoSQL 数据源&#xff0c;在线可视化编写 SQL 快速发布接口…

作者头像 李华
网站建设 2026/5/28 5:31:11

玩手机看手机打电话检测数据集VOC+YOLO格式2332张2类别

注意数据集中存在少量增强&#xff0c;且图片里面人脸都经过遮挡处理数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件)图片数量(jpg文件个数)&#xff1a;2332标注数量(xml文件个…

作者头像 李华
网站建设 2026/5/22 17:59:06

springbootWIKI知识库系统设计与实现-开题报告

目录 开题报告背景与意义系统设计目标关键技术选型预期成果研究计划 项目技术支持可定制开发之功能亮点源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作 开题报告背景与意义 随着信息化发展&#xff0c;知识管理需求日益增长&#xff0c;传…

作者头像 李华
网站建设 2026/5/28 15:46:05

磁盘清理不删除文件:找出原因并修复

当您的 Windows PC 空间开始不足时&#xff0c;您可能首先想到的工具之一就是磁盘清理。这款内置实用程序可帮助您删除不必要的文件、临时数据和缓存的系统文件&#xff0c;从而释放存储空间。然而&#xff0c;许多用户会遇到磁盘清理程序运行后却无法真正删除所选文件的问题。…

作者头像 李华