hdu_4742_Pinball Game 3D(cdq分治+树状数组)
题意:
给你n个点,让你求三维的LIS,并且求出有多少种组合能达到LIS。
题解:
求三维的LIS,典型的三维偏序问题,x排序,解决一维,cdq分治y,解决一维,树状数组维护z,解决一维。
注意,cdq中sort不要调用太多,不然会被卡常。
#include<bits/stdc++.h>
#define F(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
typedef pair<int,int>P; const int N=1e5+,mod=<<;
int t,n,hsh_ed,hsh[N];
P sum[N],dp[N]; struct node
{
int x,y,z,id;
bool operator <(const node & b)const{return x<b.x||(x==b.x&&y<b.y)||(x==b.x&&y==b.y&&z<b.z);}
}a[N],b[N]; inline void up(P &a,P b)
{
if(a.first==b.first)a.second+=b.second;
else if(a.first<b.first)a=b;
}
inline void add(int x,P c){while(x<=hsh_ed)up(sum[x],c),x+=x&-x;}
inline P ask(int x){P an=P(,);while(x)up(an,sum[x]),x-=x&-x;return an;}
inline void back(int x){while(x<=hsh_ed)sum[x]=P(,),x+=x&-x;} void cdq(int l,int r)
{
if(l==r)return;
int mid=l+r>>;
cdq(l,mid);
F(i,l,r)b[i]=a[i],b[i].x=;
sort(b+l,b++r);
F(i,l,r)
{
if(b[i].id<=mid)add(b[i].z,dp[b[i].id]);
else
{
P now=ask(b[i].z);
if(now.first+>dp[b[i].id].first)dp[b[i].id]=P(now.first+,now.second);
else if(now.first+==dp[b[i].id].first)dp[b[i].id].second+=now.second;
}
}
F(i,l,r)if(b[i].id<=mid)back(b[i].z);
cdq(mid+,r);
} int main()
{
scanf("%d",&t);
while(t--)
{
scanf("%d",&n),hsh_ed=;
F(i,,n)
{
scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].z);
hsh[i]=a[i].z;
}
sort(a+,a++n);
sort(hsh+,hsh++n),hsh_ed=unique(hsh+,hsh++n)-hsh;
F(i,,n)
{
dp[i]=P(,),a[i].id=i;
a[i].z=lower_bound(hsh+,hsh++hsh_ed,a[i].z)-hsh;
}
cdq(,n);
P ans=P(,);
F(i,,n)up(ans,dp[i]);
printf("%d %d\n",ans.first,ans.second%mod);
}
return ;
}
hdu_4742_Pinball Game 3D(cdq分治+树状数组)的更多相关文章
- Hdu4742-Pinball Game 3D(cdq分治+树状数组)
Problem Description RD is a smart boy and excel in pinball game. However, playing common 2D pinball ...
- HDU 4247 Pinball Game 3D(cdq 分治+树状数组+动态规划)
Pinball Game 3D Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- 【BZOJ4553】[Tjoi2016&Heoi2016]序列 cdq分治+树状数组
[BZOJ4553][Tjoi2016&Heoi2016]序列 Description 佳媛姐姐过生日的时候,她的小伙伴从某宝上买了一个有趣的玩具送给他.玩具上有一个数列,数列中某些项的值可能 ...
- BZOJ 1176 Mokia CDQ分治+树状数组
1176: [Balkan2007]Mokia Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 1854 Solved: 821[Submit][St ...
- 【bzoj3262】陌上花开 CDQ分治+树状数组
题目描述 有n朵花,每朵花有三个属性:花形(s).颜色(c).气味(m),又三个整数表示.现要对每朵花评级,一朵花的级别是它拥有的美丽能超过的花的数量.定义一朵花A比另一朵花B要美丽,当且仅当Sa&g ...
- 【bzoj2225】[Spoj 2371]Another Longest Increasing CDQ分治+树状数组
题目描述 给定N个数对(xi, yi),求最长上升子序列的长度.上升序列定义为{(xi, yi)}满足对i<j有xi<xj且yi<yj. 样例输入 8 1 3 3 2 1 1 4 5 ...
- BZOJ 2683 简单题 cdq分治+树状数组
题意:链接 **方法:**cdq分治+树状数组 解析: 首先对于这道题,看了范围之后.二维的数据结构是显然不能过的.于是我们可能会考虑把一维排序之后还有一位上数据结构什么的,然而cdq分治却可以非常好 ...
- LOJ3146 APIO2019路灯(cdq分治+树状数组)
每个时刻都形成若干段满足段内任意两点可达.将其视为若干正方形.则查询相当于求历史上某点被正方形包含的时刻数量.并且注意到每个时刻只有O(1)个正方形出现或消失,那么求出每个矩形的出现时间和消失时间,就 ...
- BZOJ 4553 [Tjoi2016&Heoi2016]序列 ——CDQ分治 树状数组
考虑答案的构成,发现是一个有限制条件的偏序问题. 然后三个维度的DP,可以排序.CDQ.树状数组各解决一维. #include <map> #include <cmath> # ...
随机推荐
- 启动web项目,报内存不足错误的解决方法
Initialization of bean failed; nested exception is java.lang.OutOfMemoryError: Java heap space 原因: 在 ...
- android studio 将library导出为jar 亲测成功
本人使用的是helloChart这个开源项目,其主要用于图表,来自git 地址为:https://github.com/lecho/hellocharts-android 下载命令为 git clon ...
- C#数字类型及运算符
- python2 基础
标识符 标识符是由字母,下划线和字母组成的字符序列标识符必须以字母,下划线开头,不能以数字开头标识符不能是关键字标识符可以为任意长度 算术运算符+-*///**% 科学记数法 aEb 或者aE+b例: ...
- openstack私有云布署实践【11.3 计算nova - compute节点-nova用户免密登录(用于云主机冷迁移+扩展云主机大小)】
云主机迁移+扩展云主机大小 ,官方说它依赖nova用户之间的免密登录.确保每个resion区域的compute节点服务器他们可以相互SSH免密 compute1-7 他们相互SSH免密 k ...
- IOS Android支持中文与本地文件的读取写入
转自http://www.xuanyusong.com/archives/1069 和http://www.benmutou.com/archives/2094 前几天有个朋友问我为什么在IOS平台中 ...
- Mysql登录后看不到数据库
进入数据库后,只能看到information_schema/test这两个库,其他的数据库都看不到,这是权限出了问题. 关闭Mysql /usr/local/mysql/support-files/m ...
- supervisor启动流程
Supervisor结构: 单点结构如图: 1. 初始化时,启动进程Supervisor,根据 Nimbus分配的任务情况触发启动/停用Worker Jvm进程! 2. 每个Worker进程启动一个 ...
- Java中eclipse中添加源码依赖
Window ->Preferences ->Java->instanlled jres ->editrt.jarsource attachment一般在jdk的目录下的sr ...
- css,js零散知识的整理
在同一个dom上以冒泡和捕获的方式绑定一个事件,如果事件源是该元素,则是先绑定的哪一个就先执行哪一个,事件源是dom的子孙节点,则先执行捕获事件