题意:现在有一个点堆, 一开始先给你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. X-Admin&ABP框架开发-系统日志

    网站正常运行中有时出现异常在所难免,查看系统运行日志分析问题并能够根据错误信息快速解决问题尤为重要,ABP对于系统运行日志这块已经做了很好的处理,默认采用的Log4Net已经足够满足开发过程中的需要了 ...

  2. Tomcat发布War包或者Maven项目

    在tomcat的conf目录下面的server.xml中修改如下: Host name="localhost"  appBase="webapps" unpac ...

  3. Hadoop 系列(三)—— 分布式计算框架 MapReduce

    一.MapReduce概述 Hadoop MapReduce 是一个分布式计算框架,用于编写批处理应用程序.编写好的程序可以提交到 Hadoop 集群上用于并行处理大规模的数据集. MapReduce ...

  4. JAVA jobs

    Java岗位1, SpringMVC, spring, mybaits2, 高并发编程3, mysql或者oracle SQL调优及函数,存储过程,JOB调度

  5. Jquery.form异步上传文件常见问题解决

    Jquery.form常用方法我就不多说,主要说一下在使用过程中碰到的问题 1.提示 “xxxx” is not define 或者"xxx" is not a function ...

  6. 初试kafka消息队列中间件二(采用java代码收发消息)

    初试kafka消息队列中间件二(采用java代码收发消息) 上一篇 初试kafka消息队列中间件一 今天的案例主要是将采用命令行收发信息改成使用java代码实现,根据上一篇的接着写: 先启动Zooke ...

  7. Go中的命名规范

    1.命名规范 1.1 Go是一门区分大小写的语言. 命名规则涉及变量.常量.全局函数.结构.接口.方法等的命名. Go语言从语法层面进行了以下限定:任何需要对外暴露的名字必须以大写字母开头,不需要对外 ...

  8. 通过Blazor使用C#开发SPA单页面应用程序(3)

    今天我们来看看Blazor开发的一些基本知识. 一.Blazor组件结构 Blazor中组件的基本结构可以分为3个部分,如下所示: //Counter.razor //Directives secti ...

  9. Linux与Unix到底有什么不同?

    来自:开源中国 原文:Linux vs. Unix: What's the difference? 链接: https://opensource.com/article/18/5/difference ...

  10. Jenkins使用aqua-microscanner-plugin进行容器漏洞扫描

    官方地址:https://github.com/jenkinsci/aqua-microscanner-plugin Step1 在jenkins安装"Aqua MicroScanner&q ...