题目描述

题解:

对于第一问,我们求二维LIS即可;

对于第二问,我们可以记录向前最长长度,向前最长方案数,向后最长长度,向后最长方案数。

其实改改树状数组即可。

还有,方案数一定要开double。

代码:

#include<vector>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define N 50050
inline int rd()
{
int f=,c=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){c=*c+ch-'';ch=getchar();}
return f*c;
}
int n;
struct node
{
int h,v,s,f,g;
double w1,w2;
}p[N],tmp[N];
bool cmph(node a,node b)
{
return a.h>b.h;
}
bool cmpH(node a,node b)
{
return a.h<b.h;
}
bool cmps(node a,node b)
{
return a.s<b.s;
}
struct pR
{
int x,y;
}ph[N],pv[N];
struct Pair
{
int x;
double y;
Pair(){x=,y=0.0;}
Pair(int x,double y):x(x),y(y){}
};
bool cmp(pR a,pR b)
{
return a.x<b.x;
}
struct BIT
{
Pair v[N];
void up(int x,int d,double c)
{
while(x<N)
{
if(v[x].x<d)v[x]=Pair(d,c);
else if(v[x].x==d)v[x].y+=c;
x+=(x&-x);
}
}
void clear(int x)
{
while(x<N&&v[x].x)
{
v[x]=Pair(,0.0);
x+=(x&-x);
}
}
Pair down(int x)
{
Pair ret;
while(x)
{
if(v[x].x>ret.x)ret=v[x];
else if(v[x].x==ret.x)ret.y+=v[x].y;
x-=(x&-x);
}
return ret;
}
}tr;
int max_v;
void cdq(int l,int r)
{
if(l==r)return ;
int mid = (l+r)>>;
cdq(l,mid);
sort(p+l,p+mid+,cmph);
sort(p+mid+,p+r+,cmph);
int i,j;
for(i=mid+,j=l;i<=r;i++)
{
while(j<=mid&&p[i].h<=p[j].h)
{
tr.up(max_v-p[j].v,p[j].f,p[j].w1);
j++;
}
Pair tm = tr.down(max_v-p[i].v);
if(p[i].f<tm.x+)
{
p[i].f=tm.x+;
p[i].w1=tm.y;
}else if(p[i].f==tm.x+)p[i].w1+=tm.y;
}
for(j=j-;j>=l;j--)tr.clear(max_v-p[j].v);
sort(p+l,p+r+,cmps);
cdq(mid+,r);
}
void CDQ(int l,int r)
{
if(l==r)return ;
int mid = (l+r)>>;
CDQ(mid+,r);
sort(p+l,p+mid+,cmpH);
sort(p+mid+,p+r+,cmpH);
int i,j;
for(i=l,j=mid+;i<=mid;i++)
{
while(j<=r&&p[i].h>=p[j].h)
{
tr.up(p[j].v,p[j].g,p[j].w2);
j++;
}
Pair tm = tr.down(p[i].v);
if(p[i].g<tm.x+)
{
p[i].g=tm.x+;
p[i].w2=tm.y;
}else if(p[i].g==tm.x+)p[i].w2+=tm.y;
}
for(j=j-;j>mid;j--)tr.clear(p[j].v);
sort(p+l,p+r+,cmps);
CDQ(l,mid);
}
int ans;
int main()
{
n=rd();
for(int h,v,i=;i<=n;i++)
{
h=rd(),v=rd();
ph[i].x=h,ph[i].y=i;
pv[i].x=v,pv[i].y=i;
p[i].s=i;
}
sort(ph+,ph++n,cmp);
for(int las=-,k=,i=;i<=n;i++)
{
if(las!=ph[i].x)
{
las = ph[i].x;
k++;
}
p[ph[i].y].h=k;
}
sort(pv+,pv++n,cmp);
for(int las=-,k=,i=;i<=n;i++)
{
if(las!=pv[i].x)
{
las = pv[i].x;
k++;
max_v=k+;
}
p[pv[i].y].v=k;
}
for(int i=;i<=n;i++)p[i].f=,p[i].w1=1.0;
cdq(,n);
for(int i=;i<=n;i++)ans=max(ans,p[i].f);
printf("%d\n",ans);
for(int i=;i<=n;i++)p[i].g=,p[i].w2=1.0;
CDQ(,n);
double sum = ;
for(int i=;i<=n;i++)
{
if(p[i].f+p[i].g-==ans)
{
sum+=p[i].w1*p[i].w2;
}
}
sum/=(double)ans;
for(int i=;i<=n;i++)
{
if(p[i].f+p[i].g-==ans)
{
printf("%.5lf ",p[i].w1*p[i].w2/sum);
}else
{
printf("0.00000 ");
}
}
printf("\n");
return ;
}

SDOI2011 拦截导弹的更多相关文章

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

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

  2. 【BZOJ2244】[SDOI2011]拦截导弹(CDQ分治)

    [BZOJ2244][SDOI2011]拦截导弹(CDQ分治) 题面 BZOJ 洛谷 题解 不难发现这就是一个三维偏序+\(LIS\)这样一个\(dp\). 那么第一问很好求,直接\(CDQ\)分治之 ...

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

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

  4. 【LG2481】[SDOI2011]拦截导弹

    [LG2481][SDOI2011]拦截导弹 题面 洛谷 题解 可以看出第一问就是一个有关偏序的\(LIS\),很显然可以用\(CDQ\)优化 关键在于第二问 概率\(P_i=\) \(总LIS数\) ...

  5. P2487 [SDOI2011]拦截导弹

    题目 P2487 [SDOI2011]拦截导弹 做\(SDOI\)有种想评黑的感觉,果然还是太弱了 做法 独立写(调)代码三个小时祭 简化题目:求二维最长不上升子序列及每个点出现在最长不上升子序列概率 ...

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

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

  7. BZOJ2244 [SDOI2011]拦截导弹 【cdq分治 + 树状数组】

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

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

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

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

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

  10. bzoj千题计划292:bzoj2244: [SDOI2011]拦截导弹

    http://www.lydsy.com/JudgeOnline/problem.php?id=2244 每枚导弹成功拦截的概率 = 包含它的最长上升子序列个数/最长上升子序列总个数 pre_len ...

随机推荐

  1. python 类装饰器

    class Test(): def __init__(self, func): print('装饰器1') self.__func = func def __call__(self): print(' ...

  2. bzoj 3625: [Codeforces Round #250]小朋友和二叉树【NTT+多项式开根求逆】

    参考:https://www.cnblogs.com/2016gdgzoi509/p/8999460.html 列出生成函数方程,g(x)是价值x的个数 \[ f(x)=g(x)*f^2(x)+1 \ ...

  3. JSR 303 - Bean Validation 模型验证

    类是转载的,不知道转的哪里的. 此类依赖 JSR 303 – Bean Validation, Hibernate Validator. 代码不能直接运行.意会一下.自己改改. import com. ...

  4. LIS && LCS && LCIS && LPS && MCS模板

    1. LIS (Longest Increasing Subsequence) O (n^2): /* LIS(Longest Increasing Subsequence) 最长上升子序列 O (n ...

  5. popoverController使用注意--转

    一.设置尺寸 提示:不建议,像下面这样吧popover的宽度和高度写死. 1 //1.新建一个内容控制器 2 YYMenuViewController *menuVc=[[YYMenuViewCont ...

  6. 转 sql 查出一张表中重复的所有记录数据

    select * from DB_PATCH awhere lower(a.db_name) in (select lower(db_name) from DB_PATCH group by lowe ...

  7. SASS @mixin 遇到的坑

    @mixin borderTop($size:1px,$type:solid,$color:red){ border-top:$size $type $color; } .border_top{ @i ...

  8. [转]VC++的类头文件

    本文转自:http://blog.csdn.net/forevertali/article/details/4370602   animal.h //在头文件中包含类的定义及类成员函数的声明 clas ...

  9. AJPFX关于Swing组件的总结

    默认布局管理器是流式布局(FlowLayout) 按钮的建立: jb1=new JButton("香蕉") 面板的建立:jp1=new JPanel(); 设置JFrame的标题: ...

  10. UISegmentedControl去掉背景色与UIScrollView联动

    UISegmentControl分段控制器是UIKit框架提供的一组按钮栏,提供多个可选的按钮,只能激活其中的一个,响应事件.主要用来在同一层次重要性下不同的信息展示或者不同的界面展示之间切换.例如手 ...