BJWC2018上学路线
题目描述
小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M)。
小B 家住在西南角,学校在东北角。现在有T 个路口进行施工,小B 不能通过这些路口。小B 喜欢走最短的路径到达目的地,因此他每天上学时都只会向东或北行走;而小B又喜欢走不同的路径,因此他问你按照他走最短路径的规则,他可以选择的不同的上学路线有多少条。由于答案可能很大,所以小B 只需要让你求出路径数mod P 的值。
输入输出格式
输入格式:
第一行为四个整数N、M、T、P。
接下来的T 行,每行两个整数,表示施工的路口的坐标。
输出格式:
一行一个整数,表示路径数mod P 的值。
此题涉及到的数论知识有很多:扩展欧几里得算法、卢卡斯定理(组合数)、中国剩余定理(合并)。
当没有施工点时,答案即C(n+m,m)。
当有施工点时,考虑到j点能影响到i点当且仅当x[i]>=x[j]且y[i]>=y[j]时。影响的路径条数为f[i]=f[i]-f[j]*C(a[i].x-a[j].x+a[i].y-a[j].y,a[i].x-a[j].x),它的解释为:到j点的路径条数乘上j点到i点的路径条数。我们把所有符合条件的j都减去(思考一下这样为什么不会重复减去)。计算之前先sort一遍就可以了,对于取模,卢卡斯定理计算就好了。
但模数不是质数的情况,中国剩余定理合并即可。
Code
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
using namespace std;
long long mod,n,m,t,p,jie[],ni[],f[],x,y,a1,a2,a3,a4,ans;
struct fe
{
long long x,y;
}a[];
bool cmp(fe a,fe b)
{
return(a.x==b.x)?(a.y<b.y):(a.x<b.x);
}
long long lucas(long long n,long long m)
{
if(m>n)return ;
if(!m)return ;
if(n<mod)return jie[n]*ni[m]*ni[n-m]%mod;
return lucas(n%mod,m%mod)*lucas(n/mod,m/mod)%mod;
}
void exgcd(long long a,long long b)
{
if(!b)
{
x=;
y=;
return;
}
exgcd(b,a%b);
long long k=x;
x=y;
y=k-a/b*y;
}
long long work1()
{
memset(f,,sizeof(f));
ni[]=ni[]=;
jie[]=;
for(int i=;i<=mod;++i)
{
jie[i]=(jie[i-]*i)%mod;
ni[i]=(mod-mod/i)*ni[mod%i]%mod;
}
for(int i=;i<=mod;++i)
ni[i]=ni[i]*ni[i-]%mod;
for(int i=;i<=t;++i)
{
f[i]=lucas(a[i].x+a[i].y,a[i].x)%mod;
for(int j=;j<i;++j)
if(a[i].x>=a[j].x&&a[i].y>=a[j].y)f[i]=(f[i]-f[j]*lucas(a[i].x-a[j].x+a[i].y-a[j].y,a[i].x-a[j].x)%mod+mod)%mod;
}
return f[t];
}
long long bing(long long a,long long b,long long c)
{
x=;y=;
exgcd(a,c);
x=(x+c)%c;
return x*a%p*b%p;
}
int main()
{
cin>>n>>m>>t>>p;
for(int i=;i<=t;++i)scanf("%lld%lld",&a[i].x,&a[i].y);
a[++t].x=n,a[t].y=m;
sort(a+,a+t+,cmp);
if(p==)
{
mod=p;
cout<<work1();
}
else
{
mod=;a1=work1();
mod=;a2=work1();
mod=;a3=work1();
mod=;a4=work1();
ans=(ans+bing(p/,a1,))%p;//cout<<ans;
ans=(ans+bing(p/,a2,))%p;//<<ans;
ans=(ans+bing(p/,a3,))%p;//cout<<ans;
ans=(ans+bing(p/,a4,))%p;//cout<<ans;
cout<<ans;
}
return ;
}
BJWC2018上学路线的更多相关文章
- 洛谷 P4478 [BJWC2018]上学路线
洛谷 P4478 [BJWC2018]上学路线 原题 神仙题orz,竟然没有1A....容斥+卢卡斯+crt?? 首先用容斥做,记\(f[i][0/1]\)表示到i号点经过了奇数/偶数个点的方案数,因 ...
- [luogu4478 BJWC2018] 上学路线 (容斥原理+拓展lucas)
传送门 Description 小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M). 小B 家住在西南角,学校在东北角.现在有T 个路口进行施工,小B 不能通过这些路 ...
- [BJWC2018]上学路线
Description 小B 所在的城市的道路构成了一个方形网格,它的西南角为(0,0),东北角为(N,M). 小B 家住在西南角,学校在东北角.现在有T 个路口进行施工,小B 不能通过这些路口.小B ...
- 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$个位置,让他向右走: 然后就是如何处理不能走的点: ...
- codevs2693 上学路线(施工)
难度等级:黄金 2693 上学路线(施工) 题目描述 Description 问题描述 你所在的城市街道好像一个棋盘,有a条南北方向的街道和b条东西方向的街道. 南北方向a条街道从西到东依次编号为1到 ...
- BZOJ 1266: [AHOI2006]上学路线route(最短路+最小割)
第一问最短路.第二问,先把最短路的图建出来(边(u,v)满足d[s->u]+d[v->t]+d(u,v)==最短路径长度,就在图中,可以从源点和汇点分别跑一次最短路得到每个点到源点和汇点的 ...
- BZOJ 3782: 上学路线 [Lucas定理 DP]
3782: 上学路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 192 Solved: 75[Submit][Status][Discuss] ...
- BZOJ_1266_[AHOI2006]上学路线route_最小割
BZOJ_1266_[AHOI2006]上学路线route_最小割 Description 可可和卡卡家住合肥市的东郊,每天上学他们都要转车多次才能到达市区西端的学校.直到有一天他们两人参加了学校的信 ...
随机推荐
- Spring Mvc和Spring Boot读取Profile方式
spring boot java代码中获取spring.profiles.active - u013042707的专栏 - CSDN博客https://blog.csdn.net/u013042707 ...
- 1170 - BLOB/TEXT column 'CustomerName' used in key specification without a key length
[DTF] Data Transfer 企管宝_2_CRM start[DTF] Getting tables[DTF] Analyzing table: `CustomerInfo`[DTF] Ge ...
- 前K个高频元素
给定一个非空的整数数组,返回其中出现频率前 k 高的元素. 示例 1: 输入: nums = [1,1,1,2,2,3], k = 2 输出: [1,2] 示例 2: 输入: nums = [1], ...
- 关于Vue-cli 组件引入CSS样式文件
在 Vue-cli 组件 .vue 文件中引入 css 样式表出错 由于使用Vue-cli后, 引入css 样式表 不需要 多余../../ 之类路径 现在写法也发生了改变 <style ...
- python之路--MySQL 库,表的详细操作
一 库操作 数据库命名规则 可以由数字,字母,下划线,@, #, $ 区分大小写 唯一性 不能使用关键字如 create select 不能单独使用数字 最长128位 # 这些是对上次的补充. 二 ...
- Alertmanager 安装(k8s报警)
一.下载Alertmanager https://prometheus.io/download/ wget https://github.com/prometheus/alertmanager/rel ...
- EmpireCMS的使用
1.下载安装empirecms 下载完成后解压将upload目录整体上传到服务器,并更名为empirecms_test 更改目录文件的权限: chmod -R 777 empirecms_test 配 ...
- 12.k8s的存储卷创建过程
数据持久化需要数据卷.kubernetes生态提供海量的存储驱动和存储使用方式. [root@master song]# cat pod-demo.yml apiVersion: v1 kind: P ...
- hdu—3861(tarjan+二分图)
题意:给你n个城市,每个城市之间有一条有向边,将城市划分为几个区域,问你最小的划分方法, 划分规则为:能相互到达的放在一个区域:然后区域内的a,b两点肯定存在某种方式,使得a能到b或者b能到a(注意, ...
- 使用binlog,实现MySQL数据恢复
mysql的binlog日志,用于记录数据库的增.删.改等修改操作,默认处于关闭状态.使用binlog实现数据恢复的条件为 1.binlog日志功能已开启 2.若binlog在数据库创建一段时候后开启 ...