真他娘的搞不懂cdq分治的顺序问题。但是candy?的博客里提到过,多想想吧……

#include <algorithm>
#include <iostream>
#include <cstdio>
using namespace std;
typedef pair<int,int> par;
int T, n, num[100005], tot;
const int mod=1<<30;
par ans[100005], c[100005];
struct Node{
int x, y, z, id;
}a[100005], b[100005];
bool cmp(Node u, Node v){
if(u.x!=v.x) return u.x<v.x;
else if(u.y!=v.y) return u.y<v.y;
else return u.z<v.z;
}
bool cmp2(Node u, Node v){
if(u.y!=v.y) return u.y<v.y;
else return u.z<v.z;
}
int lb(int x){
return x & -x;
}
void getRet(par &x, par y){
if(x.first<y.first) x = y;
else if(x.first==y.first)
x.second = (x.second + y.second) % mod;
}
void add(int x, par y){
for(; x<=tot; x+=lb(x))
getRet(c[x], y);
}
par query(int x){
par re=par(0, 0);
for(; x; x-=lb(x))
getRet(re, c[x]);
return re;
}
void clr(int x){
for(; x<=tot; x+=lb(x))
c[x] = par(0, 0);
}
void cdq(int l, int r){
if(l==r) return ;
int mid=(l+r)>>1;
cdq(l, mid);
for(int i=l; i<=r; i++)
b[i] = a[i];
sort(b+l, b+1+r, cmp2);
for(int i=l; i<=r; i++){
if(b[i].id<=mid)
add(b[i].z, ans[b[i].id]);
else{
par tmp=query(b[i].z);
tmp.first++;
getRet(ans[b[i].id], tmp);
}
}
for(int i=l; i<=r; i++)
if(b[i].id<=mid)
clr(b[i].z);
cdq(mid+1, r);
}
int main(){
cin>>T;
while(T--){
scanf("%d", &n);
for(int i=1; i<=n; i++){
scanf("%d %d %d", &a[i].x, &a[i].y, &a[i].z);
num[i] = a[i].z;
}
sort(num+1, num+1+n);
tot = unique(num+1, num+1+n) - num - 1;
sort(a+1, a+1+n, cmp);
for(int i=1; i<=n; i++){
a[i].id = i;
ans[i] = par(1, 1);
a[i].z = lower_bound(num+1, num+1+tot, a[i].z) - num;
}
cdq(1, n);
par tmp=par(0, 0);
for(int i=1; i<=n; i++)
getRet(tmp, ans[i]);
printf("%d %d\n", tmp.first, tmp.second);
}
return 0;
}

hdu4742 Pinball Game 3D的更多相关文章

  1. HDU-4742 Pinball Game 3D 三维LIS

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4742 题意:求3维的LIS.. 用分治算法搞得,参考了cxlove的题解.. 首先按照x排序,然后每个 ...

  2. HDU 4247 Pinball Game 3D(cdq 分治+树状数组+动态规划)

    Pinball Game 3D Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  3. hdu 4742 Pinball Game 3D(三维LIS&amp;cdq分治&amp;BIT维护最值)

    Pinball Game 3D Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  4. hdu 4742 Pinball Game 3D 分治+树状数组

    离散化x然后用树状数组解决,排序y然后分治解决,z在分治的时候排序解决. 具体:先对y排序,solve(l,r)分成solve(l,mid),solve(mid+1,r), 然后因为是按照y排序,所以 ...

  5. bryce1010专题训练——CDQ分治

    Bryce1010模板 CDQ分治 1.与普通分治的区别 普通分治中,每一个子问题只解决它本身(可以说是封闭的) 分治中,对于划分出来的两个子问题,前一个子问题用来解决后一个子问题而不是它本身 2.试 ...

  6. Hdu4742-Pinball Game 3D(cdq分治+树状数组)

    Problem Description RD is a smart boy and excel in pinball game. However, playing common 2D pinball ...

  7. 2D、3D形变

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 17.0px Monaco; color: #a5b2b9 } span.Apple-tab-span { ...

  8. CSS3 3D立方体效果-transform也不过如此

    CSS3系列已经学习了一段时间了,第一篇文章写了一些css3的奇技淫巧,原文戳这里,还获得了较多网友的支持,在此谢过各位,你们的支持是我写文章最大的动力^_^. 那么这一篇文章呢,主要是通过一个3D立 ...

  9. 三分钟学会用 js + css3 打造酷炫3D相册

    之前发过该文,后来不知怎么回事不见了,现在重新发一下. 中秋主题的3D旋转相册 如图,这是通过Javascript和css3来实现的.整个案例只有不到80行代码,我希望通过这个案例,让正处于迷茫期的j ...

随机推荐

  1. groupadd

    功能说明:用于创建新的用户组. 参数选项:-g gid 指定用户组的gid,除非接-o参数,否则ID值唯一且不为负,如果不指定-g参数,则gid从500开始.-f 新增一个账户,强制覆盖一个已存在的组 ...

  2. 【洛谷5292】[HNOI2019] 校园旅行(思维DP)

    点此看题面 大致题意: 给你一张无向图,每个点权值为\(0\)或\(1\),多组询问两点之间是否存在一条回文路径. 暴力\(DP\) 首先,看到\(n\)如此之小(\(n\le5000\)),便容易想 ...

  3. (第三场) H Diff-prime Pairs 【数论-素数线性筛法+YY】

    题目链接 题目描述 Eddy has solved lots of problem involving calculating the number of coprime pairs within s ...

  4. STL - rope 【强大的字符串处理容器】

    包含头文件: #include<ext/rope> using namespace __gnu_cxx; 申请: rope text; 基本操作: test.push_back(x); / ...

  5. javascript DOM 操作基础知识小结

    经常用到javascript对dom,喜欢这方便的朋友也很多,要想更好的对dom进行操作,这些基础一定要知道的.   DOM添加元素,使用节点属性  <!DOCTYPE html PUBLIC ...

  6. idea + maven + webapp 项目搭建

    1.File-> New -> Project

  7. SpringMVC学习记录三——8 springmvc和mybatis整合

    8      springmvc和mybatis整合 8.1      需求 使用springmvc和mybatis完成商品列表查询. 8.2      整合思路 springmvc+mybaits的 ...

  8. AngularJS 表格(带有CSS样式)

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  9. o'Reill的SVG精髓(第二版)学习笔记——第五章

    第五章 文档结构 5.1 结构与表现 XML的目标之一便是提供一种能将结构从视觉表示中独立出来的方法. 但是不幸的是,关于XML的很多讨论都强调结构而非表现. 我们将通过详细讨论如何在SVG中指定表现 ...

  10. 跨Vlan通信:单臂路由,三层交换机

    实验涉及命令以及知识补充(涉及Vlan通过的以太网口需要设置为Trunk口) 单臂路由 父接口 no ip address :删除实现单臂路由接口的IP no shutdown 虚拟子接口 R2(co ...