【BZOJ】2253: [2010 Beijing wc]纸箱堆叠
题意
三维严格偏序最长链。(\(n \le 50000\))
分析
按第一维排序然后以第二和第三维作为关键字依次加入一个二维平面,维护前缀矩形最大值。
题解
当然可以树套树....可是似乎没有随机化算法快..
于是我们上加了强剪枝的kdtree....kdtree大法好...
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=50105;
struct node;
int A, P, Te=1, top;
struct ip {
int p[3], d;
node *ptr;
void scan() {
for(int i=0; i<3; ++i) {
Te=(ll)A*Te%P;
p[i]=Te;
}
sort(p, p+3);
swap(p[0], p[1]);
swap(p[1], p[2]);
d=0; ptr=0;
}
}a[N], *b[N];
struct node *null;
struct node {
node *c[2], *f;
int x[2], y[2], mx;
ip *d;
void up() {
x[0]=min(d->p[0], min(c[0]->x[0], c[1]->x[0]));
x[1]=max(d->p[0], max(c[0]->x[1], c[1]->x[1]));
y[0]=min(d->p[1], min(c[0]->y[0], c[1]->y[0]));
y[1]=max(d->p[1], max(c[0]->y[1], c[1]->y[1]));
}
void up2() {
mx=max(d->d, max(c[0]->mx, c[1]->mx));
}
bool check(ip *a, int k) {
return x[k]<a->p[0] && y[k]<a->p[1];
}
bool ok(ip *a) {
return d->p[0]<a->p[0] && d->p[1]<a->p[1];
}
void init(ip *a) {
c[0]=c[1]=null;
x[0]=x[1]=a->p[0];
y[0]=y[1]=a->p[1];
mx=0;
d=a;
}
}Po[N], *iT=Po, *root, *st[N];
node *newnode(ip *a) {
iT->init(a);
return iT++;
}
int nowDep;
bool cmp(const ip *x, const ip *y) {
return x->p[nowDep]==y->p[nowDep]?x->p[nowDep^1]<y->p[nowDep^1]:x->p[nowDep]<y->p[nowDep];
}
void build(int l, int r, node *&x, int dep) {
if(l>r) {
x=null;
return;
}
nowDep=dep;
int mid=(l+r)>>1;
nth_element(b+l, b+mid, b+1+r, cmp);
x=newnode(b[mid]);
b[mid]->ptr=x;
build(l, mid-1, x->c[0], dep^1); if(x->c[0]!=null) x->c[0]->f=x;
build(mid+1, r, x->c[1], dep^1); if(x->c[1]!=null) x->c[1]->f=x;
x->up();
}
int askMx;
void ask(ip *a, node *x) {
if(x==null || !x->check(a, 0) || x->mx<=askMx) {
return;
}
if(x->check(a, 1)) {
askMx=max(askMx, x->mx);
}
if(x->ok(a)) askMx=max(askMx, x->d->d);
ask(a, x->c[0]);
ask(a, x->c[1]);
}
void update(node *x) {
for(x->up2(); x!=root; x=x->f, x->up2());
}
int n;
int main() {
null=iT++;
null->x[0]=null->y[0]=~0u>>1;
null->x[1]=null->y[1]=-(~0u>>1);
null->d=0; null->mx=0;
scanf("%d%d%d", &A, &P, &n);
for(int i=1; i<=n; ++i) {
a[i].scan();
b[i]=&a[i];
}
build(1, n, root, 0);
int ans=0;
nowDep=2;
sort(b+1, b+1+n, cmp);
for(int i=1; i<=n; ++i) {
askMx=0;
ask(b[i], root);
b[i]->d=askMx+1;
st[++top]=b[i]->ptr;
if(i!=n && b[i]->p[2]!=b[i+1]->p[2]) {
while(top) update(st[top--]);
}
ans=max(ans, b[i]->d);
}
printf("%d\n", ans);
return 0;
}
【BZOJ】2253: [2010 Beijing wc]纸箱堆叠的更多相关文章
- BZOJ 2253: [2010 Beijing wc]纸箱堆叠
题目 2253: [2010 Beijing wc]纸箱堆叠 Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 239 Solved: 94 Descr ...
- BZOJ2253: [2010 Beijing wc]纸箱堆叠
题解: 其实就是求三维偏序最长链.类似于三维逆序对,我们可以用树状数组套平衡树来实现. DP方程 :f[i]=max(f[j]+1) a[j]<a[i] 我们按一维排序,另一位建立树状数组,把第 ...
- 【BZOJ2253】[2010 Beijing wc]纸箱堆叠 cdq分治
[BZOJ2253][2010 Beijing wc]纸箱堆叠 Description P 工厂是一个生产纸箱的工厂.纸箱生产线在人工输入三个参数 n p a , , 之后,即可自动化生产三边边长为 ...
- BZOJ_2253_[2010 Beijing wc]纸箱堆叠 _CDQ分治+树状数组
BZOJ_2253_[2010 Beijing wc]纸箱堆叠 _CDQ分治+树状数组 Description P 工厂是一个生产纸箱的工厂.纸箱生产线在人工输入三个参数 n p a , , 之后, ...
- BZOJ2253 2010 Beijing wc 纸箱堆叠 CDQ分治
这题之前度娘上没有CDQ分治做法,gerwYY出来以后写了一个.不过要sort3遍,常数很大. gerw说可以类似划分树的思想优化复杂度,但是蒟蒻目前不会划分树(会了主席树就懒得去弄了). 嗯 将me ...
- bzoj 2252 [ 2010 Beijing wc ] 矩阵距离 —— 多源bfs
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2252 又没能自己想出来... 一直在想如何从每个1开始广搜更新答案,再剪剪枝,什么遇到1就不 ...
- 【BZOJ】【2253】【WC 2010 BeijingWC】纸箱堆叠
树套树 Orz zyf 我的树套树不知道为啥一直WA……只好copy了zyf的写法TAT 这题还可以用CDQ分治来做……但是蒟蒻不会…… //y坐标的树状数组是按权值建的……所以需要离散化…… /** ...
- 纸箱堆叠 bzoj 2253
纸箱堆叠 (1s 128MB) box [问题描述] P 工厂是一个生产纸箱的工厂.纸箱生产线在人工输入三个参数 n, p, a 之后,即可自动化生产三边边长为 (a mod P, a^2 mod p ...
- 【BZOJ2253】纸箱堆叠 [CDQ分治]
纸箱堆叠 Time Limit: 30 Sec Memory Limit: 256 MB[Submit][Status][Discuss] Description P 工厂是一个生产纸箱的工厂. 纸 ...
随机推荐
- Overview and Evaluation of Bluetooth Low Energy: An Emerging Low-Power Wireless Technology
转自:http://www.mdpi.com/1424-8220/12/9/11734/htm Sensors 2012, 12(9), 11734-11753; doi:10.3390/s12091 ...
- wifi基础知识整理
转自 :http://blog.chinaunix.net/uid-9525959-id-3326047.html WIFI基本知识整理 这里对wifi的802.11协议中比较常见的知识做一个基本的总 ...
- Android的两种事件处理机制
UI编程通常都会伴随事件处理,Android也不例外,它提供了两种方式的事件处理:基于回调的事件处理和基于监听器的事件处理. 对于基于监听器的事件处理而言,主要就是为Android界面组件绑定特定的事 ...
- MySQL5.6 on Windows 安装失败: String was not recognized as a valid DateTime
在Win7,32位上安装MySQL5.6.21时出现日期/时间格式错误, 如下图所示: 错误描述为: String was not recognized as a valid DateTime. 下面 ...
- 【leetcode】Sqrt(x)
题目描述: Implement int sqrt(int x). Compute and return the square root of x. 实现开根号,并且返回整数值(这个很重要,不是整数的话 ...
- Chrome书签被篡改之后的恢复
chrome书签和备份存放的路径:(XXXX为用户名)(AppData文件夹为隐藏文件夹) \Users\XXXX\AppData\Local\Google\Chrome\User Data\Defa ...
- unfortunately launcher has stopped
设定虚拟机的配置.
- [Liferay6.2]Connect to ajax.googleapis.com …… timed out
启动liferay 6.2 tomcat之后,后台会报一大段的异常信息,主要异常信息如下: -- :: org.apache.shindig.gadgets.http.BasicHttpFetcher ...
- VC 快速创建多层文件夹
BOOL CreateDirectory( LPCTSTR lpPathName, LPSECURITY_ATTRIBUTES lpSecurityAttributes ); 这个是大多数用户都知道的 ...
- 权限管理AppOpsManager
AppOps工具类 import android.annotation.TargetApi; import android.app.AppOpsManager; import android.cont ...