BZOJ 2244 [SDOI2011]拦截导弹 ——CDQ分治
三维偏序,直接CDQ硬上。
正反两次CDQ统计结尾的方案数,最后统计即可。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
#define F(i,j,k) for (int i=j;i<=k;++i)
#define D(i,j,k) for (int i=j;i>=i;--i)
#define ll long double
#define maxn 50005
struct Mis{
int id,h,v;
void print()
{
printf("The ID %d High %d Speed %d\n",id,h,v);
}
}a[maxn];
int f[maxn][2],n,h[maxn],v[maxn],htop,vtop;
ll g[maxn][2];
bool cmp1(Mis a,Mis b){return a.id<b.id;}
bool cmp2(Mis a,Mis b){return a.h<b.h;}
int mx[maxn]; ll cnt[maxn];
void add(int x,int f,ll g)
{
for (;x<maxn;x+=x&(-x))
if (mx[x]==f) cnt[x]+=g;
else if (mx[x]<f) mx[x]=f,cnt[x]=g;
else break;
}
int qmx(int x)
{
int ret=0;
for (;x;x-=x&(-x)) ret=max(ret,mx[x]);
return ret;
}
ll qcnt(int x,int m)
{
ll ret=0;
for (;x;x-=x&(-x))
if (mx[x]==m) ret+=cnt[x];
return ret;
}
void del(int x)
{
for (;x<maxn;x+=x&(-x)) cnt[x]=mx[x]=0;
}
void CDQ(int l,int r,int flag)
{
if (l==r)
{
if (f[a[l].id][flag]<1)
{
g[a[l].id][flag]=f[a[l].id][flag]=1;
}
return ;
}
int mid=l+r>>1;
sort(a+l,a+r+1,cmp1);
CDQ(l,mid,flag);
sort(a+l,a+mid+1,cmp2);
sort(a+mid+1,a+r+1,cmp2);
int pl=l;
F(i,mid+1,r)
{
while (a[pl].h<=a[i].h&&pl<=mid) add(a[pl].v,f[a[pl].id][flag],g[a[pl].id][flag]),pl++;
int tmp=qmx(a[i].v)+1;
if (tmp==1) continue;
if (tmp>f[a[i].id][flag])
{
f[a[i].id][flag]=tmp;
g[a[i].id][flag]=qcnt(a[i].v,tmp-1);
}
else if (tmp==f[a[i].id][flag])
g[a[i].id][flag]+=qcnt(a[i].v,tmp-1);
}
F(i,l,pl-1) del(a[i].v);
CDQ(mid+1,r,flag);
}
void print()
{
int ans=0;
F(i,1,n) ans=max(ans,f[i][0]);
printf("%d\n",ans);
ll sum=0;
F(i,1,n) if (f[i][0]==ans) sum+=g[i][0]*g[n-i+1][1];
F(i,1,n)
{
if (f[i][0]+f[n-i+1][1]-1==ans) printf("%.5Lf ",g[i][0]*g[n-i+1][1]/sum);
else printf("0 ");
}
}
int main()
{
scanf("%d",&n);htop=vtop=n;
F(i,1,n)
{
scanf("%d%d",&a[i].h,&a[i].v);
a[i].id=i;h[i]=a[i].h;v[i]=a[i].v;
}
sort(h+1,h+htop+1); sort(v+1,v+vtop+1);
htop=unique(h+1,h+htop+1)-h-1; vtop=unique(v+1,v+vtop+1)-v-1;
F(i,1,n)
{
a[i].h=lower_bound(h+1,h+htop+1,a[i].h)-h;
a[i].v=lower_bound(v+1,v+vtop+1,a[i].v)-v;
}
F(i,1,n)
{
a[i].h=htop-a[i].h+1;
a[i].v=vtop-a[i].v+1;
}
CDQ(1,n,0);
F(i,1,n)
{
a[i].id=n-a[i].id+1;
a[i].v=vtop-a[i].v+1;
a[i].h=htop-a[i].h+1;
}
CDQ(1,n,1);
print();
}
BZOJ 2244 [SDOI2011]拦截导弹 ——CDQ分治的更多相关文章
- bzoj 2244: [SDOI2011]拦截导弹 cdq分治
2244: [SDOI2011]拦截导弹 Time Limit: 30 Sec Memory Limit: 512 MBSec Special JudgeSubmit: 237 Solved: ...
- BZOJ 2244: [SDOI2011]拦截导弹 (CDQ分治 三维偏序 DP)
题意 略- 分析 就是求最长不上升子序列,坐标取一下反就是求最长不下降子序列,比较大小是二维(h,v)(h,v)(h,v)的比较.我们不看概率,先看第一问怎么求最长不降子序列.设f[i]f[i]f[i ...
- BZOJ 2244: [SDOI2011]拦截导弹 [CDQ分治 树状数组]
传送门 题意:三维最长不上升子序列以及每个元素出现在最长不上升子序列的概率 $1A$了好开心 首先需要从左右各求一遍,长度就是$F[0][i]+F[1][i]-1$,次数就是$G[0][i]*G[1] ...
- BZOJ 2244: [SDOI2011]拦截导弹 DP+CDQ分治
2244: [SDOI2011]拦截导弹 Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度.并且能够拦截 ...
- [BZOJ2244][SDOI2011]拦截导弹 CDQ分治
2244: [SDOI2011]拦截导弹 Time Limit: 30 Sec Memory Limit: 512 MB Special Judge Description 某国为了防御敌国的导弹 ...
- bzoj 2244 [SDOI2011]拦截导弹(DP+CDQ分治+BIT)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2244 [题意] 给定n个二元组,求出最长不上升子序列和各颗导弹被拦截的概率. [思路] ...
- BZOJ2244: [SDOI2011]拦截导弹(CDQ分治,二维LIS,计数)
Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度.并且能够拦截任意速度的导弹,但是以后每一发炮弹都不能高 ...
- bzoj 2244: [SDOI2011]拦截导弹
#include<cstdio> #include<iostream> #include<algorithm> #define M 100009 using nam ...
- bzoj 2244 [SDOI2011]拦截导弹(dp+CDQ+树状数组)
传送门 题解 看了半天完全没发现这东西和CDQ有什么关系…… 先把原序列翻转,求起来方便 然后把每一个位置表示成$(a,b,c)$其中$a$表示位置,$b$表示高度,$c$表示速度,求有多少个位置$a ...
随机推荐
- fiddler+willow问题总结
本文纯属用来记录自己学习过程中遇到的坑,如有朋友也遇到,可移步到这里查看是否为该问题导致. fiddler 安装不用说了,到官网直接去下载,自行下载最新版本 willow下载地址:http://qzo ...
- 【Web应用-大文件部署】上传超过 2M 的文件到 Azure PHP 网站失败
问题描述 上传超过 2M 的文件到 Azure PHP 网站失败. 问题分析 由于 PHP 本身默认上传文件的上限是 2M,所以当上传超过2M的文件时会报错. 解决方法 根据以下步骤进行配置: 在 s ...
- MySQL存储引擎问题
一.什么是存储引擎 数据库就是一种对数据进行管理和存储的软件,而它能够实现存储和管理数据的原因就是因为存储引擎的存在,存储引擎就是对存储数据.为存储的数据建立索引以及更新.查询数据等技术的实现方法:在 ...
- How to install Eclipse in linux
http://askubuntu.com/questions/26632/how-to-install-eclipse
- 51nod 1089 最长回文子串 V2(Manacher算法)
基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 输入N求N的阶乘的10进制表示的长度.例如6! = 720,长度为3. Input 第1行:一个数T,表示后面用作输入 ...
- 使用Kubernetes里的job计算圆周率后2000位
使用Kubernetes里的job(作业),我们可以很方便地执行一些比较耗时的操作. 新建一个job.ymal文件: 定义了一个Kubernetes job,名称为pi,类型为job,容器名称为pi, ...
- poj3264 划分树
题意: 给定一个序列,询问区间中最大数减去最小数的结果 和2104差不多, 代码贴过来就OK了 #include <iostream> #include <algorithm> ...
- CSS3与弹性盒布局
1.弹性盒布局对齐模式 1.1.弹性盒子 在规定弹性盒子之中的子级元素换行显示之前父级元素必须是弹性盒子模型,也就是设置 display 为 flex 代码如下: <!DOCTYPE html& ...
- 给我说说你能想到几种分布式session实现
附录: https://mp.weixin.qq.com/s/8Hh4j0CjfF5S8zM29JZl2w # 面试官心理分析 面试官问了你一堆 dubbo 是怎么玩儿的,你会玩儿 dubbo 就可以 ...
- 获取url请求的参数值
function getURLParameter(name) { return decodeURIComponent((new RegExp('[?|&]' + name + '=' + '( ...