博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
三维偏序 cdq
阅读量:6717 次
发布时间:2019-06-25

本文共 1574 字,大约阅读时间需要 5 分钟。

就是将逆序对转化到了三维上去

原理等我寒假再补

第一维sort解决

第二维并归排序(cdq)解决

第三维树状数组

// luogu-judger-enable-o2#include 
#include
#include
#include
using std::sort;const int maxn=101000;const int Max=201000;struct node{ int a,b,c; int size,ans; bool operator <= (const node &A) { if(b!=A.b) return b<=A.b; if(c!=A.c) return c<=A.c; return c<=A.c; }};node Q[maxn],tmp[maxn];int base[Max],t[Max],len,Tim;int TOT[Max<<1];int n,m;void add(int pos,int val,int T){ while(pos<=len) { if(t[pos]!=T) { t[pos]=T; base[pos]=0; } base[pos]+=val; pos+=(pos&(-pos)); } return ;}int sum(int pos,int T){ int res=0; while(pos) { if(t[pos]!=T) { t[pos]=T; base[pos]=0; } res+=base[pos]; pos-=(pos&(-pos)); } return res;}bool compare(const node &a,const node &b){ if(a.a!=b.a) return a.a
>1,o=0,T=++Tim; cdq(l,mid);cdq(mid+1,r); int q=l,p=mid+1; while(q<=mid&&p<=r) { if(Q[q]<=Q[p])//按照第二维顺序,左区间的元素算贡献(利用bit),右区间的元素进行第三维元素的顺序对查询 { add(Q[q].c,Q[q].size,T);//利用时间戳 tmp[o++]=Q[q++];//回收元素 } else { Q[p].ans+=sum(Q[p].c,T); tmp[o++]=Q[p++]; } } while(q<=mid) tmp[o++]=Q[q++];//将没有处理的元素压回tmp while(p<=r) { Q[p].ans+=sum(Q[p].c,T); tmp[o++]=Q[p++]; } for(int i=0;i

转载于:https://www.cnblogs.com/Lance1ot/p/10271917.html

你可能感兴趣的文章
PyCharm 设置小计
查看>>
underscorejs
查看>>
Linux网络——GW总结
查看>>
2017-08-06 前端日报
查看>>
canvas基础知识
查看>>
Go语言暴力入门1
查看>>
Java线程汇总
查看>>
javascript实现浏览器Ctrl+F页面搜索功能
查看>>
自己简单实现Spring的IOC原理
查看>>
解析Json更快的Gson的APT版本开源库
查看>>
慎用!BLEU评价NLP文本输出质量存在严重问题
查看>>
WebAssembly Studio:Mozilla提供的WASM工具
查看>>
专访何红辉:谈谈Android源码中的设计模式
查看>>
不用鼠标/键盘/显示器给树莓派安装系统
查看>>
InfoQ宣布成立CNUT容器技术俱乐部 欲连接中国容器社区
查看>>
你知道为什么Facebook的API以一个循环作为开头吗?
查看>>
Product Mastery 作者访谈
查看>>
极限编程创始人Ron Jeffries建议开发者放弃敏捷
查看>>
SSPL的MongoDB再被抛弃,GUN Health也合流PostgreSQL
查看>>
SegmentFault 2016 第四季度 Top Writer
查看>>