【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 工厂是一个生产纸箱的工厂. 纸 ...
随机推荐
- wpf template的code写法
this.Template = XamlReader.Load ("<ControlTemplate xmlns='http://schemas.microsoft.com/clien ...
- php 常见的问题
1. this指针错误的引用变量($(php)<->*(c)) $this->inputData right wrong 2. json_encode(array) 不一定按数组关键 ...
- 智能车学习(二十一)——浅谈CCD交叉以及横线摆放
一.CCD为何要交叉摆放? 首先使用横线摆放,CCD前瞻如果远一点,弯道丢线,再远一点直接窜道.所以需要很多很多代码的工作量,而且过弯的过程相当于没有任何的调节过程,就是一个偏差保持,或者 ...
- 如何解决""No boot device available(无可用的引导设备)”错误
首先换一个镜像文件试一试,如果还不行就按以下方法尝试 http://www.parallelsdesktop.cn/xnjxt-wydsb.html Parallels Desktop 常见问题 ht ...
- java Clone使用方法详解
java"指针" Java语言的一个优点就是取消了指针的概念,但也导致了许多程序员在编程中常常忽略了对象与引用的区别,本文会试图澄清这一概念.并且由于Java不能 通过 ...
- jsp include指令
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"% ...
- eclipse->project->clean…作用
其实主要作用就是把编译好的class等文件删除,激活eclipse的自动编译.解决的问题就是,有时候你把代码改了,但因为一些未知的原因,eclipse的自动编译没有成功,导致运行结果不正常.当你的工程 ...
- nodejs随记02
Basic认证 检查报文头中Authorization字段,由认证方式和加密值构成: basic认证中,加密值为username:password,然后进行Base64编码构成; 获取username ...
- 【转】】Android ADB命令大全
ADB很强大,记住一些ADB命令有助于提高工作效率. 获取序列号: adb get-serialno 查看连接计算机的设备: adb devices 重启机器: adb reboot 重启到bootl ...
- Delphi 包的设计思想及它与PAS、BPL、DCU、DLL、OXC的关系。
DCP ,BPL分别是什么文件,起什么作用?你在DELPHI中建立一个package然后保存一下,看看. bpl和Dll比较相似.只是BPL是BORLAND自己弄出来的东西!!!调用也和调用DLL相似 ...