题意:现在有一个点堆, 一开始先给你m个点,然后再用题目中的rand函数生成剩下的n个点,问在这个点堆中可以找到的最长严格递增序列的长度是多少。

题解:

很常见的一个3维CDQ。

先按照z轴 sort 一遍,然后对于当前的序列去cdq分治。对于CDQ的每一层来说,都是用左边的点的值去更新右边点的值,对于每一层来说, 我们按照x轴sort, sort的时候注意,当同x的时候,一定是右边的询问点要在左边的修改点前面, 不然就不能保证前面的都是合法点, 对于每一个添加点来说,我们在其y轴对应的位置更新他的长度值, 对于每一个询问点来说, 我们在查询其y轴对应的位置的下面的地方去询问最长值。

但是题目中要求的是严格递增序列。

我们发现,会有中间的那一部分存在同z值的情况导致,中间偏左的点不能去更新中间偏右的点,但是我们可以发现,这个情况只会出现一个位置,对于每一次分治来说,那么我们开2个树状数组,去维护这个东西,一个梳妆数组存下左边的所有的更新点的值, 另一个梳妆数组维护 除去前面中间偏左不能维护中间偏右的那些点以外的值。

代码:

 #include<bits/stdc++.h>
using namespace std;
#define Fopen freopen("_in.txt","r",stdin); freopen("_out.txt","w",stdout);
#define LL long long
#define ULL unsigned LL
#define fi first
#define se second
#define pb push_back
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define lch(x) tr[x].son[0]
#define rch(x) tr[x].son[1]
#define max3(a,b,c) max(a,max(b,c))
#define min3(a,b,c) min(a,min(b,c))
typedef pair<int,int> pll;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const LL mod = (int)1e9+;
const int N = 3e5 + ;
int ans[N];
int a, b, C = ~(<<), M = (<<)-;
int r(){
a = * (a & M) + (a >> );
b = * (b & M) + (b >> );
return (C&((a<<)+b)) % ;
}
struct Node{
int id, x, y, z;
}q[N], tmp[N];
bool cmp1(Node & n1, Node & n2){
return n1.z < n2.z;
}
bool cmp2(Node & n1, Node & n2){
if(n1.x != n2.x) return n1.x < n2.x;
return n1.id > n2.id;
}
int yyy[N];
int tree[][N];
void Add(int x, int val, int op){
for(int i = x; i < N; i+=i&(-i))
tree[op][i] = max(tree[op][i], val);
return ;
}
int query(int x, int op){
int ret = ;
for(int i = x; i > ; i -= i&(-i))
ret = max(tree[op][i], ret);
return ret;
}
void Clear(int x, int op){
for(int i = x; i < N; i+=i&(-i))
tree[op][i] = ;
return ;
}
void cdq(int l,int r){
if(l == r) {
ans[l] = max(ans[l], );
return ;
}
int m = l+r >> ;
cdq(l, m);
for(int i = l; i <= r; i++)
tmp[i] = q[i];
int midz = q[m+].z;
sort(tmp+l, tmp+r+, cmp2);
for(int i = l; i <= r; i++){
if(tmp[i].id <= m){
Add(tmp[i].y,ans[tmp[i].id],);
if(tmp[i].z != midz) Add(tmp[i].y,ans[tmp[i].id],);
}
else{
int val;
if(tmp[i].z != midz) val = query(tmp[i].y-, );
else val = query(tmp[i].y-,);
ans[tmp[i].id] = max(ans[tmp[i].id], val+);
}
}
for(int i = l; i <= r; i++){
if(tmp[i].id <= m){
Clear(tmp[i].y, );
if(tmp[i].z != midz) Clear(tmp[i].y,);
}
}
cdq(m+, r);
}
int main(){
int m, n, A, B;
while(~scanf("%d%d%d%d", &n, &m, &A, &B) && n+m+A+B){
a = A, b = B;
for(int i = ; i <= n; i++){
scanf("%d%d%d", &q[i].x, &q[i].y, &q[i].z);
yyy[i] = q[i].y;
}
for(int i = n+; i <= n+m; i++){
q[i].x = r(); q[i].y = r(); q[i].z = r();
yyy[i] = q[i].y;
}
sort(yyy+, yyy++n+m);
sort(q+, q++n+m, cmp1);
int ysz = unique(yyy+,yyy++n+m) - yyy - ;
for(int i = ; i <= n+m; i++){
q[i].id = i;
q[i].y = lower_bound(yyy+,yyy++ysz,q[i].y) - yyy;
ans[i] = ;
}
cdq(, n+m);
int fans = ;
for(int i = ; i <= n+m; i++)
fans = max(fans, ans[i]);
printf("%d\n", fans);
}
return ;
}

UVALive - 6667 Longest Chain CDQ3维问题的更多相关文章

  1. UvaLive 6667 Longest Chain (分治求三元组LIS&amp;树状数组)

    题目链接: here 题意: 和hdu4742类似.差别就是一部分三元组是直接给出的.另一部分是用他给的那个函数生成的.还有就是这里的大于是严格的大于a>b必须ax>bx,ay>by ...

  2. 2Sigma OA prepare: Longest Chain

    DP use HashMap: 根据string的长度sort,然后维护每个string的longest chain,default为1,如果删除某个char生成的string能提供更长的chain, ...

  3. UVALive - 7374 Racing Gems 二维非递减子序列

    题目链接: http://acm.hust.edu.cn/vjudge/problem/356795 Racing Gems Time Limit: 3000MS 问题描述 You are playi ...

  4. LeetCode 1048. Longest String Chain

    原题链接在这里:https://leetcode.com/problems/longest-string-chain/ 题目: Given a list of words, each word con ...

  5. (Problem 14)Longest Collatz sequence

    The following iterative sequence is defined for the set of positive integers: n n/2 (n is even) n 3n ...

  6. [LeetCode] Maximum Length of Pair Chain 链对的最大长度

    You are given n pairs of numbers. In every pair, the first number is always smaller than the second ...

  7. [Swift]LeetCode646. 最长数对链 | Maximum Length of Pair Chain

    You are given n pairs of numbers. In every pair, the first number is always smaller than the second ...

  8. 646. Maximum Length of Pair Chain(medium)

    You are given n pairs of numbers. In every pair, the first number is always smaller than the second ...

  9. 646. Maximum Length of Pair Chain 最长的链条长度

    [抄题]: You are given n pairs of numbers. In every pair, the first number is always smaller than the s ...

随机推荐

  1. C++ protobuffer 前后端通信 简单应用

    后端发送多个protobuffer消息到前端,前端用socket监听,如何区分消息类型呢? //定义心跳包 DseHeartbeat _DseHeartbeat; DseHeartbeat _DseH ...

  2. JS 中获得根目录

    /*** * 获得根目录 * @returns */ function getRootPath() { var strFullPath = window.document.location.href; ...

  3. DesignPattern系列__04里氏替换原则

    1.内容引入--继承体系的思考 在继承中,凡是在父类已经实现的方法,其实算是一种契约或者规范,子类不应该在进行更改(重写):但是,由于这一点不是强制要求,所以当子类进行重写的时候,就会对继承体系产生破 ...

  4. manifest.json 解析--手机web app开发笔记(三-1)

    在HBuilderX生成的文档中,还有一个“manifest.json”,只要是创建“移动App”应用,都会在工程下生成这个文件,一看扩展名就知道他是一个json格式文件,文件文件根据w3c的weba ...

  5. 分布式ID系列(5)——Twitter的雪法算法Snowflake适合做分布式ID吗

    介绍Snowflake算法 SnowFlake算法是国际大公司Twitter的采用的一种生成分布式自增id的策略,这个算法产生的分布式id是足够我们我们中小公司在日常里面的使用了.我也是比较推荐这一种 ...

  6. 100天搞定机器学习|Day17-18 神奇的逻辑回归

    前情回顾 机器学习100天|Day1数据预处理 100天搞定机器学习|Day2简单线性回归分析 100天搞定机器学习|Day3多元线性回归 100天搞定机器学习|Day4-6 逻辑回归 100天搞定机 ...

  7. IntelliJ IDEA提升效率开发插件必备

    工欲善其事,必先利其器,好的工具可以提升我们的开发效率,下面介绍几款个人觉得比较好的编辑器插件,不仅炫酷更重要可以提高你的工作效率. 本文是作者辛苦整理的16款插件,每个都是超级实用的,不好不介绍,相 ...

  8. 如果有人问你 Dubbo 中注册中心工作原理,就把这篇文章给他

    注册中心作用 开篇首先想思考一个问题,没有注册中心 Dubbo 还能玩下去吗? 当然可以,只要知道服务提供者地址相关信息,消费者配置之后就可以调用.如果只有几个服务,这么玩当然没问题.但是生产服务动辄 ...

  9. 在Docker for Windows中运行GUI程序

    Docker运行GUI原理 Docker目前大多应用在服务器领域,那么在Docker中可以运行GUI程序吗?怀着好奇心google了一番,还真有人写了一篇文章 running-gui-applicat ...

  10. 玩转VSCode插件之Remote-SSH

    前言 每当更换电脑就要从新搭建一遍开发环境... 每当拉完最新代码程序在本地跑不起来的时候就要检查服务器和开发电脑的环境... 每当服务器上出Bug的时候就想如果可以能够调试服务器代码多好啊.. 你是 ...