【学习笔记】CDQ分治(等待填坑)
因为我对CDQ分治理解不深,所以这篇博客只是我现在的浅显理解有任何不对的,希望大佬指出。
首先就是CDQ分治适用的题型:
(1)带修改,但修改互相独立
(2)必须允许离线
(3)解决数据结构的题,能把在线的数据结构吊打
CDQ分治更多的是一种思想,所以就更加没有模板了,只有一个大体的构造在那里。
下面就说一下CDQ分治的基本思想(我的认为):
CDQ分治本质上就是按时间分治,即把各个操作按时间排序然后进行处理。
其实把这个思想说出来真的不好弄,就看一道经典例题来观察一下什么是CDQ分治
题目描述:
基本思路:
这道题就是CDQ分治的必做题,三维偏序,一句话题解就是:CDQ分治第一维,归并排序第二维,数据结构第三维。即CDQ分治保证第一维有序,在这个前提下对这个序列进行归并排序,这样能保证第二维有序,在归并排序加入的过程中用数据结构存储第三维的信息,这样查找数据结构上的信息也就使得第三维有序。
代码实现:
(不确定这个代码会成为我的最终版代码)
文本版:
#include<bits/stdc++.h>
using namespace std;
const int MAXN = 2e5+5;
struct node{
int x,y,z,size,ans;
node(int _x = 0,int _y = 0,int _z = 0,int _size = 1,int _ans = 0){
x = _x, y = _y,z = _z,size = _size,ans = _ans;
}
}a[MAXN],c[MAXN];
int cnt,n,k,tree[MAXN],ans[MAXN];
int lowbit(int x){
return x & (-x);
}
void Add(int x,int y){
while(x <= k){
tree[x] += y;
x += lowbit(x);
}
}
int get_sum(int x){
int res = 0;
while(x){
res += tree[x];
x -= lowbit(x);
}
return res;
}
bool cmp_x(node l,node r){ //因为我们会进行去重,所以这里应该按顺序一个个全排
if(l.x != r.x)
return l.x < r.x;
if(l.y != r.y)
return l.y < r.y;
return l.z < r.z;
}
bool cmp_y(node l,node r){
if(l.y != r.y)
return l.y < r.y;
return l.z < r.z;
}
void cdq(int l,int r){
if(l >= r)
return;
int mid = (l + r)>>1;
cdq(l,mid);cdq(mid+1,r);
sort(c+l,c+mid+1,cmp_y);sort(c+mid+1,c+r+1,cmp_y);
int i = mid+1,j = l;
while(i <= r){
while(j <= mid && c[i].y >= c[j].y){
Add(c[j].z,c[j].size);
j++;
}
c[i].ans += get_sum(c[i].z);
i++;
}
for(int h = l; h < j; h++){
Add(c[h].z,-c[h].size);
}
}
int main(){
// freopen("in.txt","r",stdin);
// freopen("out.txt","w",stdout);
cin>>n>>k;
for(int i=1; i<=n; i++){
cin>>a[i].x>>a[i].y>>a[i].z;
}
sort(a+1,a+n+1,cmp_x);
c[++cnt] = a[1];
c[cnt].size = 1;
for(int i=2; i<=n; i++){
if(a[i].x != a[i-1].x || a[i].y != a[i-1].y || a[i].z != a[i-1].z){
c[++cnt] = a[i];
c[cnt].size = 1;
}
else{
c[cnt].size++;
}
}
cdq(1,cnt);
for(int i=1; i<=cnt; i++){
ans[c[i].ans + c[i].size - 1]+=c[i].size;
}
for(int i=0; i<n; i++){
printf("%d\n",ans[i]);
}
return 0;
}
【学习笔记】CDQ分治(等待填坑)的更多相关文章
- 学习笔记 | CDQ分治
目录 前言 啥是CDQ啊(它的基本思想) 例题 后记 参考博文 前言 博主太菜了 学习快一年的OI了 好像没有什么会的算法 更寒碜的是 学一样还不精一样TAT 如有什么错误请各位路过的大佬指出啊感谢! ...
- [学习笔记] CDQ分治 从感性理解到彻底晕菜
最近学了一种叫做CDQ分治的东西...用于离线处理一系列操作与查询似乎跑得很快233 CDQ的名称似乎源于金牌选手陈丹琦 概述: 对于一坨操作和询问,分成两半,单独处理左半边和处理左半边对于右半边的影 ...
- [学习笔记]CDQ分治和整体二分
序言 \(CDQ\) 分治和整体二分都是基于分治的思想,把复杂的问题拆分成许多可以简单求的解子问题.但是这两种算法必须离线处理,不能解决一些强制在线的题目.不过如果题目允许离线的话,这两种算法能把在线 ...
- [学习笔记] CDQ分治&整体二分
突然诈尸.png 这两个东西好像都是离线骗分大法... 不过其实这两个东西并不是一样的... 虽然代码长得比较像 CDQ分治 基本思想 其实CDQ分治的基本思想挺简单的... 大概思路就是长这样的: ...
- 学习笔记——CDQ分治
再次感谢这位大佬的博客:https://www.cnblogs.com/ljc20020730/p/10395866.html CDQ分治,是一种在分治合并中计算前面值对后面答案的贡献的一种算法.今天 ...
- Python3+Selenium3+webdriver学习笔记14(等待判断 鼠标事件 )
!/usr/bin/env python -*- coding:utf-8 -*-'''Selenium3+webdriver学习笔记14(等待判断 鼠标事件 )'''from selenium im ...
- CDQ分治_占坑
准备系统地学习一波CDQ分治,持续更新中... 首先,CDQ分治也还是分治的一种,只不过普通分治是独立的解决两个子问题,而CDQ分治还要计算第一个子问题对于第二个的影响. CDQ分治几乎都是用来解决多 ...
- 算法笔记--CDQ分治 && 整体二分
参考:https://www.luogu.org/blog/Owencodeisking/post-xue-xi-bi-ji-cdq-fen-zhi-hu-zheng-ti-er-fen 前置技能:树 ...
- 准备写一些读书笔记,最近在填坑 SQL学习指南 Spring in Action effective Java
把一些读书的理解通过白板图的形式展示出来,加深自己的认识, 因为目前没有工程项目练手,暂时在学习中把这些知识深化认识一下
随机推荐
- 《前端运维》五、k8s--3灰度发布、滚动更新与探针
一.灰度发布 灰度发布是一种发布方式,也叫金丝雀发布,起源是矿工在下井之前会先放一只金丝雀到井里,如果金丝雀不叫了,就代表瓦斯浓度高.原因是金丝雀对瓦斯气体很敏感.灰度发布的做法是:会在现存旧应用的基 ...
- Java容器基础概况
一.什么是Java容器 书写程序时,我们常常需要对大量的对象引用进行管理.为了实现有效的归类管理,我们常常将同类的引用放置在同一个数据容器中.Java容器类是java提供的工具包,包含了常用的数据结构 ...
- STM32试题及答案
一.选择题 1.Cortex-M处理器采用的架构是( D ) (A)v4T (B)v5TE (C)v6 (D)v ...
- 一次关于关系抽取(RE)综述调研的交流心得
本文来自于一次交流的的记录,{}内的为个人体会. 基本概念 实事知识:实体-关系-实体的三元组.比如, 知识图谱:大量实时知识组织在一起,可以构建成知识图谱. 关系抽取:由于文本中蕴含大量事实知识,需 ...
- Vue.js快速介绍-超级马里奥像素艺术
原文出处:Quick Introduction to Vue.js - Super Mario Pixel Art ::代码我已经归纳在github上:[vue2-pixel-art]::::__查看 ...
- java中异常(Exception)的定义,意义和用法。举例
1.异常(Exception)的定义,意义和用法 我们先给出一个例子,看看异常有什么用? 例:1.1- public class Test { public static void main(S ...
- jsp笔记---标签
<meta>标签 <meta> 标签提供了 HTML 文档的元数据.元数据不会显示在客户端,但是会被浏览器解析. META元素通常用于指定网页的描述,关键词,文件的最后修改时间 ...
- 记住用户名和登录密码+虚拟机没有root权限解决办法
今日所学: 记住用户名和登录密码 用adb查看保存文件内容 如何使用adb 如何安装adb-百度经验 遇到的问题: 用adb查看文件时,没有权限访问data文件 出现原因:google play虚拟机 ...
- kubectl creat -f 创建pod时出错
如果创建yaml时候,sts中已经存在,但是get pod又查不到已经启动的pod可以这样 [root@k3master src]# kubectl get pod //查不到eureka NAME ...
- 企业应用架构研究系列二十七:Vue3.0 之环境的搭建与Vue Antd Admin探索
开发前端需要准备一些开发工具,这些工具怎么安装就不详细描写了,度娘一些很多很多.主要把核心的开发工具列表一些,这些资源也是非常容易找到和安装的. Node 安装:https://nodejs.org/ ...