三维偏序,直接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分治的更多相关文章

  1. bzoj 2244: [SDOI2011]拦截导弹 cdq分治

    2244: [SDOI2011]拦截导弹 Time Limit: 30 Sec  Memory Limit: 512 MBSec  Special JudgeSubmit: 237  Solved: ...

  2. BZOJ 2244: [SDOI2011]拦截导弹 (CDQ分治 三维偏序 DP)

    题意 略- 分析 就是求最长不上升子序列,坐标取一下反就是求最长不下降子序列,比较大小是二维(h,v)(h,v)(h,v)的比较.我们不看概率,先看第一问怎么求最长不降子序列.设f[i]f[i]f[i ...

  3. BZOJ 2244: [SDOI2011]拦截导弹 [CDQ分治 树状数组]

    传送门 题意:三维最长不上升子序列以及每个元素出现在最长不上升子序列的概率 $1A$了好开心 首先需要从左右各求一遍,长度就是$F[0][i]+F[1][i]-1$,次数就是$G[0][i]*G[1] ...

  4. BZOJ 2244: [SDOI2011]拦截导弹 DP+CDQ分治

    2244: [SDOI2011]拦截导弹 Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度.并且能够拦截 ...

  5. [BZOJ2244][SDOI2011]拦截导弹 CDQ分治

    2244: [SDOI2011]拦截导弹 Time Limit: 30 Sec  Memory Limit: 512 MB  Special Judge Description 某国为了防御敌国的导弹 ...

  6. bzoj 2244 [SDOI2011]拦截导弹(DP+CDQ分治+BIT)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2244 [题意] 给定n个二元组,求出最长不上升子序列和各颗导弹被拦截的概率. [思路] ...

  7. BZOJ2244: [SDOI2011]拦截导弹(CDQ分治,二维LIS,计数)

    Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度.并且能够拦截任意速度的导弹,但是以后每一发炮弹都不能高 ...

  8. bzoj 2244: [SDOI2011]拦截导弹

    #include<cstdio> #include<iostream> #include<algorithm> #define M 100009 using nam ...

  9. bzoj 2244 [SDOI2011]拦截导弹(dp+CDQ+树状数组)

    传送门 题解 看了半天完全没发现这东西和CDQ有什么关系…… 先把原序列翻转,求起来方便 然后把每一个位置表示成$(a,b,c)$其中$a$表示位置,$b$表示高度,$c$表示速度,求有多少个位置$a ...

随机推荐

  1. NSTimer 实现时钟回调方法

    在开发过程中,发现时钟调用的地方比较多.所以对时钟进行了一个简单的统一封装.具体代码如下: 1.时钟回调函数的声明: #pragma mark 时钟回调处理 //时钟回调 +(NSTimer*) ls ...

  2. iOS  UDP 广播 AsyncSocket 用法

    因为业务需要,需要用广播发送一个字段,在iOS开发中,用到了AsynSocket. 1.定义一个属性,负责发送和接受数据 #define YX_Local_Host @"255.255.25 ...

  3. log explorer使用的几个问题[转载]

    1)对数据库做了完全 差异 和日志备份备份时选用了删除事务日志中不活动的条目再用Log explorer打试图看日志时提示No log recorders found that match the f ...

  4. Oracle 存储过程调用语句

    #oracle 存储过程调用语句declare v_custName varchar2(10); --客户姓名 v_num number; --订单分布天数 v_time number; --每日订单 ...

  5. sparkmlib-相关系数

    一.基本原理 在stat包中实现了皮尔逊(Pearson)与 斯皮尔曼(Spearman)两类相关系数的计算 (1)Pearson:   (x,y)协方差/[(x标准方差)*(y标准方差)] 详情可以 ...

  6. Robot Framework(十三) 执行测试用例——创建输出

    3.5创建输出 执行测试时会创建几个输出文件,并且所有这些文件都与测试结果有某种关联.本节讨论创建的输出,如何配置它们的创建位置以及如何微调其内容. 3.5.1不同的输出文件 输出目录 输出文件 日志 ...

  7. 77 最长公共子序列 (lintcode)

    注意:因为开的空间是length+1的,对于字符串的下标计算要-1 class Solution { public: /* * @param A: A string * @param B: A str ...

  8. ios 团购信息客户端demo(三)

    接上二篇的内容,今天我们就来介绍一下如何将解析出来的数据放入AQGridView中显示出来,因为我们的工程中已经将AQGridView导入了,所以我们在KKFirstViewController中直接 ...

  9. WINDOWS下使用Mysql 中碰到的问题记录

    问题:在cmd中输入net stop mysql反馈“服务名无效” win+R打开运行窗口,输入 services.msc 查看其中mysql的服务名,比如我的是叫做MySQL80 让我们继续回到最开 ...

  10. python:json

    json是用来传输数据的字符串,{"key1":"values1","key2":{"key3":"value ...