洛谷 P4478 [BJWC2018]上学路线
洛谷 P4478 [BJWC2018]上学路线
神仙题orz,竟然没有1A。。。。容斥+卢卡斯+crt??
首先用容斥做,记\(f[i][0/1]\)表示到i号点经过了奇数/偶数个点的方案数,因为\(f[i][0]+f[i][1]=1\)所以只要记一个\(f[i]\)是经过奇数个点的方案数就行
枚举一个左下的点走到这个点,或者直接从1走到这个点,
\(f[i]=\sum_{\text{j in lower left side}}((1-f[j])\times C_{x_i+y_i-x_j-y_j}^{x_i-x_j})+C_{x_i+y_i}^{x_i}\)
答案就是从所有点走到这个点,加上从1号点走到这个点\(\sum_{i}((1-f[i])\times C_{n+m-x_i-x_j}^{n-x_i})+C_{n+m}^{n}\)
sort一遍dp就做完了,只剩下求组合数了
模数好像不是质数,分解一下发现是3×5×6793×10007
crt即可,对每个模数求一遍方案,求组合数用lucas
lucas大概就是\(C_{n}^{m}\text{mod }p=C_{\lfloor\frac{n}{p}\rfloor}^{{\lfloor\frac{m}{p}\rfloor}}\times C_{n\text{ mod }p}^{m\text{ mod }p}\mod p\)
这神仙题就做完了。。。
#include<bits/stdc++.h>
#define il inline
#define vd void
typedef long long ll;
il ll gi(){
ll x=0;
char ch=getchar();
while(!isdigit(ch))ch=getchar();
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x;
}
ll mod;
struct yyb{ll x,y;}a[210];
il bool cmp(const yyb&a,const yyb&b){
if(a.x^b.x)return a.x<b.x;
return a.y<b.y;
}
ll f[210];
ll p[5],tot;
ll Ans[5];
ll pp[5],tt[5];
ll fact[1000010],inv[1000010];
il ll C(ll n,ll m,ll P){
if(n<m)return 0;
return fact[n]*inv[fact[m]*fact[n-m]%P]%P;
}
il ll Lucas(ll n,ll m,ll P){
if(n<m)return 0;if(!n)return 1;
return Lucas(n/P,m/P,P)*C(n%P,m%P,P)%P;
}
int main(){
#ifndef ONLINE_JUDGE
freopen("4478.in","r",stdin);
freopen("4478.out","w",stdout);
#endif
ll n=gi(),m=gi(),t=gi();mod=gi();
if(mod==1000003)p[tot=1]=mod;
else p[++tot]=3,p[++tot]=5,p[++tot]=6793,p[++tot]=10007;
for(int i=1;i<=t;++i)a[i].x=gi(),a[i].y=gi();
std::sort(a+1,a+t+1,cmp);
ll M=1;
for(int i=1;i<=tot;++i)M*=p[i];
for(int i=1;i<=tot;++i)pp[i]=M/p[i];
for(int o=1;o<=tot;++o){
ll P=p[o];
inv[1]=1;for(int i=2;i<P;++i)inv[i]=(P-(P/i)*inv[P%i]%P)%P;
tt[o]=inv[pp[o]%P];
fact[0]=1;for(int i=1;i<P;++i)fact[i]=fact[i-1]*i%P;
Ans[o]=Lucas(n+m,n,P);
for(int i=1;i<=t;++i){
f[i]=Lucas(a[i].x+a[i].y,a[i].x,P);
for(int j=1;j<i;++j)
if(a[j].x<=a[i].x&&a[j].y<=a[i].y)
f[i]+=P-f[j]*Lucas(a[i].x+a[i].y-a[j].x-a[j].y,a[i].x-a[j].x,P)%P;
f[i]%=P;
Ans[o]+=P-Lucas(n+m-a[i].x-a[i].y,n-a[i].x,P)*f[i]%P;
}
Ans[o]%=P;
}
ll ans=0;
for(int i=1;i<=tot;++i)ans+=Ans[i]*pp[i]%mod*tt[i]%mod;
printf("%lld\n",ans%mod);
return 0;
}
洛谷 P4478 [BJWC2018]上学路线的更多相关文章
- P4478 [BJWC2018]上学路线
Description 小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M). 小B 家住在西南角,学校在东北角.现在有T 个路口进行施工,小B 不能通过这些路口.小B ...
- Luogu P4478 [BJWC2018]上学路线 卢卡斯+组合+CRT
首先,从$(0,0)$走到$(n,m)$的方案数是$ C_{n+m}^n$,可以把走的方向看作一种序列,这个序列长$ n+m$ ,你需要从中任取$n$个位置,让他向右走: 然后就是如何处理不能走的点: ...
- 【模板】矩阵快速幂 洛谷P2233 [HNOI2002]公交车路线
P2233 [HNOI2002]公交车路线 题目背景 在长沙城新建的环城公路上一共有8个公交站,分别为A.B.C.D.E.F.G.H.公共汽车只能够在相邻的两个公交站之间运行,因此你从某一个公交站到另 ...
- Java实现 洛谷 Car的旅行路线
输入输出样例 输入样例#1: 1 3 10 1 3 1 1 1 3 3 1 30 2 5 7 4 5 2 1 8 6 8 8 11 6 3 输出样例#1: 47.5 import java.util. ...
- BJWC2018上学路线
题目描述 小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M). 小B 家住在西南角,学校在东北角.现在有T 个路口进行施工,小B 不能通过这些路口.小B 喜欢走最短的 ...
- [luogu4478 BJWC2018] 上学路线 (容斥原理+拓展lucas)
传送门 Description 小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M). 小B 家住在西南角,学校在东北角.现在有T 个路口进行施工,小B 不能通过这些路 ...
- [BJWC2018]上学路线
Description 小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M). 小B 家住在西南角,学校在东北角.现在有T 个路口进行施工,小B 不能通过这些路口.小B ...
- 洛谷 P4484 - [BJWC2018]最长上升子序列(状压 dp+打表)
洛谷题面传送门 首先看到 LIS 我们可以想到它的 \(\infty\) 种求法(bushi),但是对于此题而言,既然题目出这样一个数据范围,硬要暴搜过去也不太现实,因此我们需想到用某种奇奇怪怪的方式 ...
- 洛谷 P2233 [HNOI2002]公交车路线 解题报告
P2233 [HNOI2002]公交车路线 题目背景 在长沙城新建的环城公路上一共有8个公交站,分别为A.B.C.D.E.F.G.H.公共汽车只能够在相邻的两个公交站之间运行,因此你从某一个公交站到另 ...
随机推荐
- 使用最新版SDWebImage
使用最新版SDWebImage 1. 下载源码: 2. 测试能否编译成功: 3. 用Xcode6新建一个工程,然后将文件夹拖入到工程当中: 4. 查看其主要的源码,发现之前使用版本的方法都被弃用了: ...
- consul日常操作命令
#开发模式运行agent consul agent -dev #查看consul 集群成员 consul members [-detailed] members命令的输出基于gossip协议,并最终一 ...
- windows:nginx配置http、https反向代理
一.下载 Windows 版本的 nginx nnginx下载:http://nginx.org/en/download.html 推荐稳定版本.下载完成后,解压得到 nginx-1.14.0 ,我把 ...
- 两周以来的学习成果&遇到的问题及解决:
1.学习java的基本内容,看慕课网上的java入门三季,与韩顺平老师的java视频 刚开始是看韩顺平老师的视频,边看边实战,内容很细,也很快熟练,但是进度太慢.后来就先看了慕课网上的java 入门的 ...
- 使用FASTJSON做反序列化的时间格式处理
JSONObject.DEFFAULT_DATE_FORMAT = "yyyy-MM-dd'T'HH:mm:ss.mmm"; Productorder tmp1 = JSONObj ...
- 笔记--Yarn
Yarn,Facebook开源一个新的Javascript包管理工具. 简介 Yarn 是一个新的包管理器,用于替代现有的 npm 客户端或者其他兼容 npm 仓库的包管理工具.Yarn 保留了现有工 ...
- mysql通过“延迟关联”进行limit分页查询优化的一个实例
最近在生产上遇见一个分页查询特别慢的问题,数据量大概有200万的样子,翻到最后一页性能很低,差不多得有4秒的样子才能出来整个页面,需要进行查询优化. 第一步,找到执行慢的sql,如下: SELECT ...
- SSM框架之关于使用JSP作为视图展示问题解决方案
JSP作为视图层展示数据,已经有很长一段时间了,不管是在校学习还是企业工作,总会或多或少接触这个.特别是对于一些传统中小型或者一些几年前的企业而言,有很多使用JSP作为视图展示层. JSP本质是就是S ...
- Visual Studio 2012 编译错误【error C4996: 'scanf': This function or variable may be unsafe. 】的解决方案
在VS 2012 中编译 C 语言项目,如果使用了 scanf 函数,编译时便会提示如下错误: error C4996: 'scanf': This function or variable may ...
- kubernetes 日志定制查阅 - 排错 -- 好用的命令
You can use kubectl logs to retrieve logs from a previous instantiation of a container with --previo ...