题目描述

题解:

对于第一问,我们求二维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. HDU6024:Building Shops(DP)

    传送门 题意 在一条直线上有n个教室,现在要设置糖果店,使得最后成本最小,满足以下两个条件: 1.若该点为糖果店,费用为cost[i]; 2.若不是,则为loc[i]-最近的糖果店的loc 分析 dp ...

  2. NOIp 2015真题模拟赛 By cellur925

    果然我还是最菜的==不接受反驳== Day1 T1:神奇的幻方 思路:直接模拟即可,由于当前放法只与上一放法有关系,用两个变量记录一下即可.10分钟内切掉== 预计得分:100分 实际得分:100分 ...

  3. Hexo瞎折腾系列(7) - Coding Pages申请SSL/TLS证书错误

    问题 今天我的个人站点SSL/TLS证书到期,我的证书是由Coding Pages提供的,每次申请成功后有效期是三个月,证书到期后可以继续免费申请.但是当我登陆进入Coding Pages服务的后台并 ...

  4. vs2015未能正确加载“ProviderPackage”包

    出现以下错误的解决方案 ---------------------------Microsoft Visual Studio---------------------------未能正确加载“Prov ...

  5. python之迷宫BFS

    # @File: maze_queue_bfs from collections import deque maze = [ [1, 1, 1, 1, 1, 1, 1, 1, 1, 1], [1, 0 ...

  6. _bzoj1911 [Apio2010]特别行动队【斜率优化dp】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1911 裸的斜率优化dp. #include <cstdio> const int ...

  7. Music in Car CodeForces - 746F

    Music in Car CodeForces - 746F 题意很难懂啊... 题意:http://blog.csdn.net/a838502647/article/details/74831793 ...

  8. 线段树(单点更新) HDOJ 2795 Billboard

    题目传送门 /* 主要利用线段树求区间最值,sum[]代表位置可用空间 每次找到最大值的位置 功能:查询最靠前能容纳广告的位置 */ #include <cstdio> #include ...

  9. magento 自定义url路径 和 filter data 小结

    背景是往一个第三方的搜索插件里面加入filter功能. 首先是路径,插件自己定义了一个router,类似于cms.那首先说说router好了,从入口一路追查的话,会发现最后进入的是Mage_Core_ ...

  10. php数组与字符串转换

    1.将字符串转换成数组的几个函数: (1)explode(separate,string) 示例:$str = "Hello world It's a beautiful day" ...