news 2026/3/7 11:24:38

《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/3/5 3:43:56

【SRC】抓包环境搭建与并发漏洞实战全解

本文仅用于技术研究&#xff0c;禁止用于非法用途。 Author:枷锁 小程序安全&#xff1a;抓包环境搭建与并发漏洞实战全解 在当前的网络安全渗透测试&#xff08;特别是 SRC 众测&#xff09;中&#xff0c;微信小程序已成为漏洞产出的“重灾区” 。小程序功能迭代快、与移动端…

作者头像 李华
网站建设 2026/2/28 22:12:34

想上传一万个宝贝到淘宝店铺,只需修改宝贝主图,如何操作?

有一位店主问我们&#xff1a;“我想用一个链接&#xff0c;上传一万个宝贝到淘宝店铺&#xff0c;只需要修改主图&#xff0c;要怎么做&#xff1f;” 下面将步骤列示如下&#xff0c;希望能给有这类需求的店主一些帮助&#xff1a;1.首先在自己店铺内做一个商品模板&#xff…

作者头像 李华
网站建设 2026/2/26 22:34:59

速看!提示工程架构师的并行计算框架最佳实践

提示工程架构师必备:并行计算框架最佳实践与落地指南 副标题:从原理到代码,用并行化解决大模型提示执行的效率瓶颈 摘要/引言 当你在设计一个复杂的提示工程系统时——比如多工具调用的提示链、批量生成1000条商品描述、或多模态(文本+图像)的提示任务——是否遇到过以…

作者头像 李华
网站建设 2026/2/22 20:24:40

提示工程架构师:用Git思维做提示版控,效率直接拉满

提示工程版控痛点救星&#xff1a;用Git思维管理Prompt&#xff0c;从此告别版本混乱 副标题&#xff1a;从0到1搭建可追溯、可协作的提示词管理流程 摘要/引言 你有没有过这样的经历&#xff1f; 改了8版提示词&#xff0c;突然想找回第3版的“神来之笔”&#xff0c;却发…

作者头像 李华