HDU5126 stars(4维偏序->cdq套cdq+树状数组)

stars

题目大意:
在一个三维空间当中,每次进行一个操作,添加一个点或者统计空间中的某一个长方体范围内的所有点

三维空间中我们用两个点即可确定一个长方体。

首先效仿平面二维数点的方法,根据容斥原理可以把询问拆分成8个以原点O(0,0,0)O(0,0,0)O(0,0,0)为一个顶点长方体的内部点的数量,像这样的长方体可以用一个坐标(x,y,z)(x,y,z)(x,y,z)表示

假设当前有一个点在t0t_0t0时刻插入位置为(x0,y0,z0)(x_0,y_0,z_0)(x0,y0,z0),如果这个点在ttt时刻一个以原点为一个端点的长方体(x,y,z)(x,y,z)(x,y,z)内部条件:t0<t,x0≤x,y0≤y,z0≤zt_0<t,x_0\leq x,y_0\leq y,z_0\leq zt0<t,x0x,y0y,z0z
由上面条件不难看出是一个4维偏序问题。
对于3维偏序三维偏序(陌上花开)只需要用cdq分治+树状数组即可解决,当然同样可以用cdq分治套cdq分治解决(强烈建议写此题前,用cdq套cdq写一下三维偏序(陌上花开))

4维偏序只需要 cdq套cdq+树状数组

注意需要对z进行离散化

#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
constexpr int N=50010;
struct node
{int op;int x,y,z;int sign,id;int part;
}q[8*N];
int n,nn,cnt;
int b[2*N],c[N];
int ans[N];
int fw[2*N];
int lowbit(int x){return x&-x;}
void update(int k,int x){for(;k<=nn;k+=lowbit(k)) fw[k]+=x;}
int query(int k){int res=0;for(;k;k-=lowbit(k)) res+=fw[k];return res;}void cdq(int l,int r)
{if(l>=r) return;int mid=l+r>>1;cdq(l,mid),cdq(mid+1,r);int i=l;for(int j=mid+1;j<=r;j++){while(i<=mid&&q[i].y<=q[j].y){if(q[i].op==0&&q[i].part==0) update(q[i].z,1);i++;}if(q[j].op==1&&q[j].part==1) ans[q[j].id]+=q[j].sign*query(q[j].z);}while(i>l) {i--;if(q[i].op==0&&q[i].part==0) update(q[i].z,-1);}inplace_merge(q+l,q+mid+1,q+r+1,[](const node&a,const node&b){return a.y<b.y;});}
void solve(int l,int r)
{if(l>=r) return;int mid=l+r>>1;solve(l,mid),solve(mid+1,r);for(int i=l;i<=mid;i++) q[i].part=0;for(int i=mid+1;i<=r;i++) q[i].part=1;stable_sort(q+l,q+r+1,[](const node&a,const node&b){return a.x<b.x;});cdq(l,r);
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);int T;cin>>T;while(T--){cin>>n;cnt=nn=0;for(int i=1;i<=n;i++) ans[i]=0,c[i]=0;for(int i=1;i<=n;i++){int op;cin>>op;if(op==1){int x,y,z;cin>>x>>y>>z;q[++cnt]={0,x,y,z};b[++nn]=z;}else{c[i]=1;int x1,y1,z1,x2,y2,z2;cin>>x1>>y1>>z1>>x2>>y2>>z2;q[++cnt]={1,x2,y2,z2,1,i};q[++cnt]={1,x1-1,y2,z2,-1,i};q[++cnt]={1,x2,y1-1,z2,-1,i};q[++cnt]={1,x2,y2,z1-1,-1,i};q[++cnt]={1,x1-1,y1-1,z2,1,i};q[++cnt]={1,x1-1,y2,z1-1,1,i};q[++cnt]={1,x2,y1-1,z1-1,1,i};q[++cnt]={1,x1-1,y1-1,z1-1,-1,i};b[++nn]=z1-1;b[++nn]=z2;}}sort(b+1,b+1+nn);nn=unique(b+1,b+1+nn)-b-1;for(int i=1;i<=cnt;i++) q[i].z=lower_bound(b+1,b+1+nn,q[i].z)-b;solve(1,cnt);for(int i=1;i<=n;i++)if(c[i]) cout<<ans[i]<<'\n';}return 0;
}

感觉网上此题的题解都好久远,难道没人水水这题吗???
1A非常开心,要加油哦~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319017.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[翻译] C# 8.0 新特性

原文: Building C# 8.0[译注:原文主标题如此&#xff0c;但内容大部分为新特性介绍&#xff0c;所以意译标题为 "C# 8.0 新特性"]C# 的下一个主要版本是 8.0。我们已经为它工作了很长一段时间&#xff0c;即使我们构建并发布了次要版本 C# 7.1, 7.2 和 7.3&#xff0…

[蓝桥杯][2018年第九届真题]搭积木

[[蓝桥杯][2018年第九届真题]搭积木](https://www.dotcpp.com/oj/problem2292.html)题目&#xff1a; 小明对搭积木非常感兴趣。他的积木都是同样大小的正立方体。 在搭积木时&#xff0c;小明选取 m 块积木作为地基&#xff0c;将他们在桌子上一字排开&#xff0c;中间不留空…

NOI.AC#2007-light【根号分治】

正题 题目链接:http://noi.ac/problem/2007 题目大意 nnn个格子排成一排&#xff0c;每个格子有一个0/10/10/1和一个颜色。开始每个格子都是000&#xff0c;qqq次操作取反一个颜色的所有格子的0/10/10/1&#xff0c;然后询问111的格子构成的连通块数量。 1≤n,q≤1051\leq n,q…

【招聘(广州)】 招聘.NET程序员

招聘&#xff1a;.NET程序员工作地点&#xff1a;广州天河区CBD&#xff08;地铁3号线珠江新城站&#xff09;职位描述&#xff1a;网站平台、移动页面、APP、微信小程序、接口等开发&#xff1b;与UI/UX&#xff0c;设计师、产品经理偕同工作一起排查、定位、优化产品性能。任…

【模板】一维树状数组

ACM模板 目录聊聊前缀和什么是树状数组?树状数组相关操作局限性差分在树状数组中的应用区间更新、单点查询区间更新、区间查询树状数组应用聊聊前缀和 比如数组 int a[7]{1,2,3,4,5,6,7}如果需询问数组从第l个数到第r个数的和暴力做法时间复杂度为O(n)O(n)O(n) 不过我们可以…

牛客题霸 单链表的选择排序 C++题解/答案

牛客题霸 单链表的选择排序 C题解/答案 题目描述 给定一个无序单链表&#xff0c;实现单链表的选择排序(按升序排序)。 题解&#xff1a; 不可能手写排序&#xff0c;这辈子不可能手写排序。。 基础的链表操作&#xff0c;将链表内的数据存到vector内&#xff0c;然后用sor…

牛客练习赛71E-神奇的迷宫【点分治,NTT】

正题 题目链接:https://ac.nowcoder.com/acm/contest/7745/E 题目大意 给出nnn个点的一棵树&#xff0c;每个点有一个选择权重aia_iai​&#xff08;有ai∑i1nai\frac{a_i}{\sum_{i1}^na_i}∑i1n​ai​ai​​的概率被选择&#xff09;。 然后有一个序列www。随机选择两次点&…

使用C#把Tensorflow训练的.pb文件用在生产环境

训练了很久的Tf模型&#xff0c;终于要到生产环境中去考验一番了。今天花费了一些时间去研究tf的模型如何在生产环境中去使用。大概整理了这些方法。继续使用分步骤保存了的ckpt文件这个貌似脱离不了tensorflow框架&#xff0c;而且生成的ckpt文件比较大&#xff0c;发布到生产…

OpenJudge1043 树上游戏(换根dp+细节处理)

树上游戏 给定一棵 nnn 个节点的树&#xff0c;点从 111 到 nnn 编号&#xff0c;点有点权&#xff0c;边有边权&#xff0c; Alice\text{Alice}Alice 和 Bob\text{Bob}Bob 两人在做游戏。 棋子以某一个点 sss 为起点&#xff0c;玩家移动该棋子&#xff0c;有以下两条规则&a…

牛客题霸 转圈打印矩阵 C++题解/答案

牛客题霸 转圈打印矩阵 C题解/答案 题目描述 给定一个整型矩阵matrix&#xff0c;请按照顺时针转圈的方式打印它。 示例1 输入 复制 [[1,2,3,4],[5,6,7,8],[9,10,11,12],[13,14,15,16]] 返回值 复制 [1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10] 题解&#xff1a; 题意很明确…

【招聘(上海)】东方财富证券招聘.net开发

东方财富证券&#xff1a;东方财富网(深创&#xff1a;300059)旗牌照齐全证券公司&#xff0c;极具互联网基因的券商。.Net服务端开发工程师/.Net前端开发工程师[职位介绍]服务端&#xff1a;开户、交易及资讯系统的后端接口服务(Asp.Net WebApi)开发&#xff1b;服务端&#x…

2020牛客NOIP赛前集训营-提高组(第三场)C-牛半仙的妹子Tree【虚树,最短路】

正题 题目链接:https://ac.nowcoder.com/acm/contest/7609/C 题目大意 给出nnn个点的一棵树&#xff0c;mmm个时刻各有一个操作 标记一个点&#xff0c;每个点被标记后的每一个时刻会标记掉周围的点。删去所有点的标记询问一个点是否有标记 解题思路 考虑没有二操作怎么搞&…

codeforces773 D. Perishable Roads(思维+最短路)

D. Perishable Roads 题意简述&#xff1a; 一个 nnn 个点的完全图 以 iii 为根节点时 询问 能构造的树的 ∑d(x)\sum d(x)∑d(x) 最小是多少。 d(x)d(x)d(x)&#xff1a; xxx 到根节点边权值最小值 MOONPIE题解 首先有一个显而易见的错误贪心&#xff1a; 不妨假设以root\t…

牛客题霸 两数之和C++题解/答案

牛客题霸 两数之和 C题解/答案 题目描述 给出一个整数数组&#xff0c;请在数组中找出两个加起来等于目标值的数&#xff0c; 你给出的函数twoSum 需要返回这两个数字的下标&#xff08;index1&#xff0c;index2&#xff09;&#xff0c;需要满足 index1 小于index2.。注意&…

P3244-[HNOI2015]落忆枫音【dp】

正题 题目链接:https://www.luogu.com.cn/problem/P3244 题目大意 给出一个DAG\text{DAG}DAG&#xff0c;保证111可以到达所有点。然后再加入一条边&#xff08;之后不一定是DAG\text{DAG}DAG&#xff09;。 求有多少棵以111为根的外向生成树。 1≤n≤105,1≤m≤21051\leq n…

EF Core 实现多租户

SAAS 和多租户SaaS(软件及服务)区别于其他应用程序的主要特征就是能够使客户在使用应用程序时按照使用量付费。他们不需要为软件购买许可&#xff0c;也不需要安装、托管和管理它。这方面的操作全部由提供 SaaS 软件的组织负责。多租户是实现 SaaS 的关键因素, 它可以让多个企业…

P3246 [HNOI2016]序列(莫队+单调栈+ST表)

[HNOI2016]序列 Tea神题解 Kelin神题解 对于莫队算法最主要的是如何快速算出[l,r]→[l,r1][l,r]\to[l,r1][l,r]→[l,r1]对答案的贡献的变化。 当询问区间发生上述变化时[l,r]→[l,r1][l,r]\to [l,r1][l,r]→[l,r1]不难发现子区间增加这些&#xff1a;[l,r1],[l1,r1],…,[r,r1…

P6672-[清华集训2016]你的生命已如风中残烛【结论】

正题 题目链接:https://www.luogu.com.cn/problem/P6672 题目大意 长度为mmm的序列aaa&#xff0c;有nnn个数字不是000&#xff0c;其他m−nm-nm−n个是000。要求重排后有多少方案满足 ∀x,∑i1xai≥i\forall x,\sum_{i1}^xa_i\geq i∀x,i1∑x​ai​≥i 其中m∑i1naim\sum_{i…

牛客题霸 反转链表 C++题解/答案

题目描述 输入一个链表&#xff0c;反转链表后&#xff0c;输出新链表的表头。 示例1 输入 复制 {1,2,3} 返回值 复制 {3,2,1} 题解&#xff1a; 如果用偷懒的方法&#xff0c;可以用vector来存链表内容&#xff0c;然后来个翻转&#xff08;vector自带&#xff09;即可 但是…

【.NET Core项目实战-统一认证平台】第五章 网关篇-自定义缓存Redis

上篇文章【.NET Core项目实战-统一认证平台】第四章 网关篇-数据库存储配置&#xff08;2&#xff09;我们介绍了2种网关配置信息更新的方法和扩展Mysql存储&#xff0c;本篇我们将介绍如何使用Redis来实现网关的所有缓存功能&#xff0c;用到的文档及源码将会在GitHub上开源&a…