求出期望 所有情况很好搞 C(n+m-2,n-1).

也就是说求出所有情况的和乘以上面总方案的逆元即可。

可以发现所有情况和经过多少个障碍点有关 和所处位置无关。

简单的设f[i]表示从1,1到n,m经过i个障碍点的方案数。

可以发现求出这个数组就得到了答案。

发现每过一个障碍点 体力就会除以2 所以过掉log个障碍点 以后体力都是1.

我们只需要求出log个取值即可。

由于障碍点之间是单向关系 所以可以从左到右dp f[i][j]表示前i个点经过了j个障碍点的方案数。

转移?f[k][j-1]?不能这样做 显然这样会有重复 我上午也思考了很久。

考虑容斥 从1,1到当前点总方案已知 -不合法方案:到达当前点经过了多余j个障碍点的方案+少于j个的方案。

观察后面的形式 我们已经推出j-1了 所以后面的已知。

前者多余j个的方案 f[k][j+1]...f[k][j+w]?显然还是会重复。

代表元容斥 考虑一条路径到达i这个点多余了j个点的这样的路径 必然存在到达i之间的某个点的状态为j 这样不管怎么走最后到i都是不合法的。

所以有f[k][j]发现这些方案不可能交叉 这也叫做代表元容斥 最小状态表示总体。

总复杂度K^2log 最后还要再多加一个点n,m来合并答案。(其实是求出一个障碍点都不经过的方案。

数组不要开小了 别像我这个傻屌一样。

const ll MAXN=200010;
ll n,m,maxx,s,w,cc;
ll f[MAXN][22],v[MAXN];//f[i][j]表示前i个点经过了j个点的方案数 第i个点必过.
struct wy{ll x,y;}t[MAXN];
ll fac[MAXN],inv[MAXN];
inline ll ksm(ll b,ll p)
{
ll cnt=1;
while(p)
{
if(p&1)cnt=cnt*b%mod;
b=b*b%mod;p=p>>1;
}
return cnt;
}
inline ll C(ll a,ll b){if(b>a)return 0;return fac[a]*inv[b]%mod*inv[a-b]%mod;}
inline void prepare()
{
fac[0]=1;
rep(1,maxx,i)fac[i]=fac[i-1]*i%mod;
inv[maxx]=ksm(fac[maxx],mod-2);
fep(maxx-1,0,i)inv[i]=inv[i+1]*(i+1)%mod;
}
inline ll cmp(wy a,wy b){return a.x==b.x?a.y<b.y:a.x<b.x;}
inline ll V(ll x,ll y)
{
ll w=t[y].x+t[y].y-t[x].x-t[x].y;
return C(w,t[y].x-t[x].x);
}
signed main()
{
freopen("rover.in","r",stdin);
freopen("rover.out","w",stdout);
get(n);get(m);get(w);get(s);
maxx=n+m;prepare();
rep(1,w,i)
{
ll get(x);ll get(y);
t[i]=(wy){x,y};
}
ll ww=s;v[0]=s;
while(1)
{
ww=(ww>>1)+(ww&1);
if(ww==1)break;
v[++cc]=ww;
}
++w;++cc;
t[w]=(wy){n,m};
sort(t+1,t+w+1,cmp);
rep(1,w,i)
{
ll sum=0;
rep(1,cc,j)
{
f[i][j]=C(t[i].x+t[i].y-2,t[i].x-1)-sum;
rep(1,i-1,k)
{
if(t[k].x<=t[i].x&&t[k].y<=t[i].y)
f[i][j]=(f[i][j]-f[k][j]*V(k,i)%mod)%mod;
}
sum=(sum+f[i][j])%mod;
}
}
ll sum=C(n+m-2,n-1);
ll ans=0;
rep(1,cc,i)
{
sum=(sum-f[w][i])%mod;
ans=(ans+f[w][i]*v[i-1])%mod;
}
ans=((ans+sum)%mod+mod)%mod;
putl(ans*ksm(C(n+m-2,n-1),mod-2)%mod);
return 0;
}

4.2 省选模拟赛 流浪者 容斥dp的更多相关文章

  1. 省选模拟赛 4.26 T1 dp 线段树优化dp

    LINK:T1 算是一道中档题 考试的时候脑残了 不仅没写优化 连暴力都打挂了. 容易发现一个性质 那就是同一格子不会被两种以上的颜色染.(颜色就三种. 通过这个性质就可以进行dp了.先按照左端点排序 ...

  2. 5.29 省选模拟赛 树的染色 dp 最优性优化

    LINK:树的染色 考场上以为这道题要爆蛋了 没想到 推出正解来了. 反正是先写了爆搜的 爆搜最近越写越熟练了 容易想到dp 容易设出状态 f[i][j]表示以i为根的子树内白色的值为j此时黑色的值怎 ...

  3. 4.26 省选模拟赛 T3 状压dp 差分求答案

    LINK:T3 比较好的题目 考试的时候被毒瘤的T2给搞的心态爆炸 这道题连正解的思路都没有想到. 一看到题求删除点的最少个 可以使得不连通. 瞬间想到最小割 发现对于10分直接跑最小割即可. 不过想 ...

  4. 4.9 省选模拟赛 圆圈游戏 树形dp set优化建图

    由于圆不存在相交的关系 所以包容关系形成了树的形态 其实是一个森林 不过加一个0点 就变成了树. 考虑对于每个圆都求出最近的包容它的点 即他的父亲.然后树形dp即可.暴力建图n^2. const in ...

  5. 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解

    今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...

  6. FCS省选模拟赛 Day1

    Description  Solution T1 shopping 目测是插板法乱搞一下 发现题解写的是容斥dp: \[ ans = \sum_i (-1)^ig[i] \] \(g[i]\)表示的有 ...

  7. HDU 5794 A Simple Chess (容斥+DP+Lucas)

    A Simple Chess 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5794 Description There is a n×m board ...

  8. [CF1086E]Beautiful Matrix(容斥+DP+树状数组)

    给一个n*n的矩阵,保证:(1)每行都是一个排列 (2)每行每个位置和上一行对应位置不同.求这个矩阵在所有合法矩阵中字典序排第几.考虑类似数位DP的做法,枚举第几行开始不卡限制,那么显然之前的行都和题 ...

  9. 【BZOJ3622】已经没有什么好害怕的了 容斥+DP

    [BZOJ3622]已经没有什么好害怕的了 Description Input Output Sample Input 4 2 5 35 15 45 40 20 10 30 Sample Output ...

随机推荐

  1. APIO强掠计划(spfa+tarjan缩点)

    强掠计划 题目大意: \(Siruseri\) 城中的道路都是单向的.不同的道路由路口连接.按照法律的规定,在每个路口都设立了一个 \(Siruseri\) 银行的 \(ATM\) 取款机.令人奇怪的 ...

  2. 「区间DP」「洛谷PP3146 」[USACO16OPEN]248 G

    [USACO16OPEN]248 G 题目: 题目描述 Bessie likes downloading games to play on her cell phone, even though sh ...

  3. 无题 II 二分图最大匹配

    题目描述 这是一个简单的游戏,在一个n*n的矩阵中,找n个数使得这n个数都在不同的行和列里并且要求这n个数中的最大值和最小值的差值最小. Input 输入一个整数T表示T组数据. 对于每组数据第一行输 ...

  4. [SpringBoot]SpringBoot中使用redis事务

    本文基于SpringBoot 2.X 事务在关系型数据库的开发中经常用到,其实非关系型数据库,比如redis也有对事务的支持,本文主要探讨在SpringBoot中如何使用redis事务. 事务的相关介 ...

  5. 萌新计划 PartⅡ

    Part Ⅱ web 9-15 这一部分的题,主要是绕过过滤条件,进行命令执行 0x01 web 9 过滤条件: if(preg_match("/system|exec|highlight/ ...

  6. 数据可视化之DAX篇(十五)Power BI按表筛选的思路

    https://zhuanlan.zhihu.com/p/121773967 ​数据分析就是筛选.分组.聚合的过程,关于筛选,可以按一个维度来筛选,也可以按多个维度筛选,还有种常见的方式是,利用几个特 ...

  7. ASP.NET Core3.1使用Identity Server4建立Authorization Server-2

    前言 建立Web Api项目 在同一个解决方案下建立一个Web Api项目IdentityServer4.WebApi,然后修改Web Api的launchSettings.json.参考第一节,当然 ...

  8. redis必知会

    Redis 是单进程单线程的? Redis 是单进程单线程的,redis 利用队列技术将并发访问变为串行访问,消 除了传统数据库串行控制的开销. Redis 的持久化机制是什么?各自的优缺点? Red ...

  9. P3406 海底高铁 (洛谷)

    题目背景 大东亚海底隧道连接着厦门.新北.博艾.那霸.鹿儿岛等城市,横穿东海,耗资1000亿博艾元,历时15年,于公元2058年建成.凭借该隧道,从厦门可以乘坐火车直达台湾.博艾和日本,全程只需要4个 ...

  10. 肝了两天IntelliJ IDEA 2020,解锁11种新姿势, 真香!!!

    IDEA2020版本正式发布已经有3个月了,当时由于各方面原因(太懒)也没有去尝试新功能.于是这个周末特意去在另一个电脑上下载了最新版的IDEA,并尝试了一下.总的来说呢,体验上明显的提升. 作为一个 ...