HDU4742----Pinball Game 3D(三维LIS、CDQ分治)
题意:三维空间内 n个小球,对应坐标(x,y,z)。输出LIS的长度以及方案数。
首先可以先按x排序,先降低一维,然后 剩下y 、z,在y上进行CDQ分治,按y的大小用前面的更新后面的。z方向离散化之后用树状数组维护就可以了。
- #include <set>
- #include <map>
- #include <cmath>
- #include <ctime>
- #include <queue>
- #include <stack>
- #include <cstdio>
- #include <string>
- #include <vector>
- #include <cstdlib>
- #include <cstring>
- #include <iostream>
- #include <algorithm>
- using namespace std;
- typedef unsigned long long ull;
- typedef long long ll;
- const int inf = 0x3f3f3f3f;
- const double eps = 1e-;
- const int maxn = 1e5+;
- const int mod = << ;
- struct Ball
- {
- int x,y,z,idx;
- bool operator < (const Ball &rhs)const
- {
- return x < rhs.x || (x == rhs.x && y < rhs.y) || (x == rhs.x && y == rhs.y && z < rhs.z);
- }
- } ball[maxn],tmpball[maxn];
- struct DP
- {
- int len,cnt;
- DP(){}
- DP(int _len,int _cnt):
- len(_len),cnt(_cnt) {}
- } dp[maxn],c[maxn];
- int vec[maxn],idx;
- inline int lowbit (int x)
- {
- return x & -x;
- }
- inline void update (DP &dp1, DP &dp2)
- {
- if (dp1.len < dp2.len)
- dp1 = dp2;
- else if (dp1.len == dp2.len)
- dp1.cnt += dp2.cnt;
- }
- inline void modify(int x,DP &d)
- {
- while (x <= idx)
- {
- update(c[x],d);
- x += lowbit(x);
- }
- }
- DP query(int x)
- {
- DP ans = DP (,);
- while (x)
- {
- update(ans,c[x]);
- x -= lowbit(x);
- }
- return ans;
- }
- inline void CLR(int x)
- {
- while (x <= idx)
- {
- c[x] = DP(,);
- x += lowbit(x);
- }
- }
- void CDQ (int l, int r)
- {
- if (l == r)
- return ;
- int mid = (l + r) >> ;
- CDQ (l, mid);
- for (int i = l; i <= r; i++)
- {
- tmpball[i] = ball[i];
- tmpball[i].x = ;
- }
- sort(tmpball+l,tmpball+r+);
- for (int i = l; i <= r; i++)
- {
- if (tmpball[i].idx <= mid)
- {
- modify(tmpball[i].z,dp[tmpball[i].idx]);
- }
- else
- {
- DP tmp = query(tmpball[i].z);
- tmp.len++;
- update(dp[tmpball[i].idx],tmp);
- }
- }
- for (int i = l; i <= r; i++)
- {
- if (tmpball[i].idx <= mid)
- {
- CLR(tmpball[i].z);
- }
- }
- CDQ (mid+, r);
- }
- int main(void)
- {
- #ifndef ONLINE_JUDGE
- freopen("in.txt","r",stdin);
- #endif
- int T, n;
- scanf ("%d",&T);
- while (T--)
- {
- scanf ("%d",&n);
- for (int i = ; i <= n; i++)
- {
- scanf ("%d%d%d",&ball[i].x, &ball[i].y, &ball[i].z);
- vec[i-] = ball[i].z;
- }
- sort (ball+, ball+n+);
- sort (vec,vec+n);
- idx = unique(vec,vec+n) - vec;
- for (int i = ; i <= n ; i++)
- {
- ball[i].z = lower_bound(vec,vec+idx,ball[i].z) - vec + ;
- ball[i].idx = i;
- dp[i] = DP(,);
- }
- CDQ(,n);
- DP ans = DP(,);
- for (int i = ; i <= n ;i++)
- {
- update(ans,dp[i]);
- }
- printf("%d %d\n",ans.len, ans.cnt % mod);
- }
- return ;
- }
HDU4742----Pinball Game 3D(三维LIS、CDQ分治)的更多相关文章
- HDU-4742 Pinball Game 3D 三维LIS
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4742 题意:求3维的LIS.. 用分治算法搞得,参考了cxlove的题解.. 首先按照x排序,然后每个 ...
- hdu 4742 Pinball Game 3D(三维LIS&cdq分治&BIT维护最值)
Pinball Game 3D Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- Luogu 3810 & BZOJ 3262 陌上花开/三维偏序 | CDQ分治
Luogu 3810 & BZOJ 3263 陌上花开/三维偏序 | CDQ分治 题面 \(n\)个元素,每个元素有三个值:\(a_i\), \(b_i\) 和 \(c_i\).定义一个元素的 ...
- bzoj3262: 陌上花开 三维偏序cdq分治
三维偏序裸题,cdq分治时,左侧的x一定比右侧x小,然后分别按y排序,对于左侧元素按y大小把z依次插入到树状数组里,其中维护每个左侧元素对右侧元素的贡献,在bit查询即可 /************* ...
- [bzoj] 3263 陌上花开 洛谷 P3810 三维偏序|| CDQ分治 && CDQ分治讲解
原题 定义一个点比另一个点大为当且仅当这个点的三个值分别大于等于另一个点的三个值.每比一个点大就为加一等级,求每个等级的点的数量. 显然的三维偏序问题,CDQ的板子题. CDQ分治: CDQ分治是一种 ...
- BZOJ3262 陌上花开 —— 三维偏序 CDQ分治
题目链接:https://vjudge.net/problem/HYSBZ-3262 3262: 陌上花开 Time Limit: 20 Sec Memory Limit: 256 MBSubmit ...
- BZOJ 3295:[Cqoi2011]动态逆序对(三维偏序 CDQ分治+树状数组)
http://www.lydsy.com/JudgeOnline/problem.php?id=3295 题意:简单明了. 思路:终于好像有点明白CDQ分治处理三维偏序了.把删除操作看作是插入操作,那 ...
- hdu4742 Pinball Game 3D
真他娘的搞不懂cdq分治的顺序问题.但是candy?的博客里提到过,多想想吧-- #include <algorithm> #include <iostream> #inclu ...
- 三维偏序[cdq分治学习笔记]
三维偏序 就是让第一维有序 然后归并+树状数组求两维 cdq+cdq不会 告辞 #include <bits/stdc++.h> // #define int long long #def ...
- cdq分治解决三维偏序
问题背景 在三维坐标系中有n个点,坐标为(xi,yi,zi). 定义一个点A比一个点B小,当且仅当xA<=xB,yA<=yB,zA<=zB.问对于每个点,有多少个点比它小.(n< ...
随机推荐
- Android ProgressDialog 加载进度
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...
- 使用CCUserDefault 推断用户是否是第一次登陆系统及UserDefault全路径的获取
bool bfirst =CCUserDefault::sharedUserDefault()->getBoolForKey("first"); //假设不能获取该键值,创建 ...
- HDFS集群balance(4)-- 测试计划
转载请注明博客地址:http://blog.csdn.net/suileisl HDFS集群balance,对应版本balance design 6 如需word版本,请QQ522173163联系索要 ...
- linux 声音大小调整的命令
alsamixer 输入上面的命令 回车即可看到图形界面,界面如下 ┌──────────────────────────── AlsaMixer v1.0.27.1 ──────────────── ...
- 通过编写一个简单的漏洞扫描程序学习Python基本语句
今天开始读<Python绝技:运用Python成为顶级黑客>一书,第一章用一个小例子来讲解Python的基本语法和语句.主要学习的内容有:1. 安装第三方库.2. 变量.字符串.列表.词典 ...
- 使用rpm安装mysql的默认目录
--使用rpm安装mysql的默认目录:1.数据库目录/var/lib/mysql/2.配置文件/usr/share/mysql(mysql.server命令及配置文件)3.相关命令/usr/bin( ...
- MVC4建立DBContext的EF6数据
MVC4建立DBContext的EF6数据时 1.需要using System.Data.Entity;命名空间 2.此命名空间需要安装EntityFromwork.dll,此dll可以在项目——&g ...
- 深入理解 CSS变形 transform(3d)
坐标轴 在了解透视之前,首先要先了解坐标轴.3D变形与2D变形最大的不同就在于其参考的坐标轴不同.2D变形的坐标轴是平面的,只存在x轴和y轴,而3D变形的坐标轴则是x.y.z三条轴组成的立体空间,x轴 ...
- crontab 配置
* * * * * (cd /opt/bd/www/crm/scripts/zb_insure; /opt/tuniu/php/bin/php /opt/bd/www/crm/scripts/zb_i ...
- Swift - 42 - 类的基本使用
import Foundation /* 1.class表示类的关键字 2.class后面表示类名 3.类名后面的大括号内表示类的内部 */ /* 1.属性封装了set和get方法 2.方法里面封装了 ...