http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1486

1486 大大走格子

题目来源: CodeForces
基准时间限制:1 秒 空间限制:131072 KB 分值: 160 难度:6级算法题
收藏
关注

有一个h行w列的棋盘,里面有一些格子是不能走的,现在要求从左上角走到右下角的方案数。

Input
单组测试数据。
第一行有三个整数h, w, n(1 ≤ h, w ≤ 10^5, 1 ≤ n ≤ 2000),表示棋盘的行和列,还有不能走的格子的数目。
接下来n行描述格子,第i行有两个整数ri, ci (1 ≤ ri ≤ h, 1 ≤ ci ≤ w),表示格子所在的行和列。
输入保证起点和终点不会有不能走的格子。
Output
输出答案对1000000007取余的结果。
Input示例
3 4 2
2 2
2 3
Output示例
2
 跟前面做过的很类似,但是增加了一些障碍格子,很闹心啊。。。容斥也不太懂,看了dp的作法还挺好懂的把,写的太丑被卡时一早上。。。
我们不妨计算出所有的方案然后减去有障碍格子的方案,令f[i]表示从(1,1)到第i个障碍点的合法路径,也就是说除了i点,路径上得点都合法。
这样的话不难得出方程  f[i]=C(xi+yi-2,xi-1)-Σj=1i-1f[j]*C(xi+yi-xj-yj,xi-xj) ;
这个方程相当于枚举了所有不合法的路径中第一个障碍格子,显然之后的所有路径都至少包含一个障碍格,所以都是非法的,
这个方程前面就是所有的路径方案,后面就是所有的包含障碍的路径方案,减去就是要求的状态了,
显然对于(a,b)-(c,d)格子间所有的路径数我们根据组合数能轻易的得到,打表就好了,注意并不是i之前的所有点都一定能到达i,记得判断一下。
如果把(h,w)看做是一个最后的障碍点的话,ans=f[n+1].
 #include<bits/stdc++.h>
using namespace std;
#define LL long long
LL mod=1e9+;
LL dp[];
LL f[],inv[];
struct node{int x,y;}P[];
int read(){
int x=;char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) x=x*+c-'',c=getchar();
return x;
}
bool cmp(node A,node B)
{
if(A.x==B.x) return A.y<B.y;
return A.x<B.x;
}
LL qpow(LL a,LL b)
{
LL r=;
while(b){
if(b&) r=r*a%mod;
a=a*a;
b>>=;
}
return r;
}
inline LL C(LL N,LL M) {return f[N]*inv[M]%mod*inv[N-M]%mod;}
int main()
{
LL h,w,n,i,j,k;
scanf("%lld%lld%lld",&h,&w,&n);
for(i=;i<=n;++i) P[i].x=read(),P[i].y=read();
sort(P+,P++n,cmp);
P[n+].x=h; P[n+].y=w;
inv[]=f[]=;
for(i=;i<=h+w;++i)
{
f[i]=i*f[i-]%mod;
inv[i]=qpow(f[i],mod-);
}
dp[]=C(P[].x+P[].y-,P[].x-);
for(i=;i<=n+;++i)
{
LL s=;
for(j=;j<i;++j)
{
if(P[j].x<=P[i].x&&P[j].y<=P[i].y)
s=(s+dp[j]*C(P[i].x+P[i].y-P[j].x-P[j].y,P[i].x-P[j].x))%mod;
}
dp[i]=(C(P[i].x+P[i].y-,P[i].x-)-s+mod)%mod;
}
printf("%lld\n",dp[n+]);
return ;
}

51nod 1486的更多相关文章

  1. 51nod 1486 大大走格子(容斥原理)

    1486 大大走格子 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: 160 难度:6级算法题   有一个h行w列的棋盘,里面有一些格子是不能走的,现在要 ...

  2. 51nod 1486 大大走格子——容斥

    题目:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1486 已知起点到某个障碍点左上角的所有点的不经过障碍的方案数,枚举 ...

  3. 51Nod 1486 大大走格子 —— 容斥

    题目:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1486 对于每个点,求出从起点到它,不经过其他障碍点的方案数: 求一 ...

  4. 51Nod 1486 大大走格子 —— 组合数学

    题目链接:https://vjudge.net/problem/51Nod-1486 1486 大大走格子 题目来源: CodeForces 基准时间限制:1 秒 空间限制:131072 KB 分值: ...

  5. 51nod 1486 大大走格子(DP+组合数学)

    枚举不合法点的思想. 把障碍x坐标为第一关键字,y坐标为第二关键字排序.f[i]表示走到第i个障碍的方案数. f[i]=C(x[i]+y[i]-2,x[i]-1)-sigma(f[j]*C(x[i]- ...

  6. 51nod 1486 大大走格子——dp

    有一个h行w列的棋盘,里面有一些格子是不能走的,现在要求从左上角走到右下角的方案数. Input 单组测试数据. 第一行有三个整数h, w, n(1 ≤ h, w ≤ 10^5, 1 ≤ n ≤ 20 ...

  7. 51nod 1486 大大走格子(容斥+dp+组合数)

    传送门 解题思路 暴力容斥复杂度太高,无法接受,考虑用\(dp\).设\(f(i)\)表示从左上角开始不经过前面的阻断点,只经过\(i\)的阻断点.那么可以考虑容斥,用经过\(i\)的总方案数减去前面 ...

  8. AtCoder Regular Contest 058

    这个应该是第一场有英文的atcoder吧??不过题解却没有英文的... 从前往后慢慢做... C こだわり者いろはちゃん / Iroha's Obsession 数据范围这么小,直接暴力 #inclu ...

  9. 【51NOD】1486 大大走格子

    [算法]动态规划+组合数学 [题意]有一个h行w列的棋盘,定义一些格子为不能走的黑点,现在要求从左上角走到右下角的方案数. [题解] 大概能考虑到离散化黑点后,中间的空格子直接用组合数计算. 然后解决 ...

随机推荐

  1. django博客项目6:Django Admin 后台发布文章

    在此之前我们完成了 Django 博客首页视图的编写,我们希望首页展示发布的博客文章列表,但是它却抱怨:暂时还没有发布的文章!如它所言,我们确实还没有发布任何文章,本节我们将使用 Django 自带的 ...

  2. swift 值得学习的项目

    http://www.php100.com/html/it/biancheng/2015/0112/8329.html

  3. 两款高性能并行计算引擎Storm和Spark比較

    对Spark.Storm以及Spark Streaming引擎的简明扼要.深入浅出的比較,原文发表于踏得网. Spark基于这种理念.当数据庞大时,把计算过程传递给数据要比把数据传递给计算过程要更富效 ...

  4. 开发微信公众平台--新建新浪云sae部署server

    创建新浪云计算应用 申请账号 我们使用SAE新浪云计算平台作为server资源.而且申请PHP环境+MySQL数据库作为程序执行环境. 申请地址:百度搜sae ,使用新浪微博账号能够直接登录SAE,登 ...

  5. linux系统下nginx安装目录和nginx.conf配置文件目录

    linux系统下nginx安装目录和nginx.conf配置文件目录 1.查看nginx安装目录 输入命令 # ps  -ef | grep nginx 返回结果包含安装目录 root      26 ...

  6. Ubuntu学习笔记1-基本部分

    Vim相当于vi的升级版 Find p*.txt支持查找通配符 Echo 回显命令 echo hello  >1.txt  追加命令,不覆盖 echo hello  >1.txt  覆盖命 ...

  7. django-ORM复习补充

    建表 class Author(models.Model): name = models.CharField(max_length=32) age = models.IntegerField() # ...

  8. GIT学习笔记(5):变基

    GIT学习笔记(5):变基rebase 变基 引入变基 在Git中整合来自不同分支的修改主要有两种方法:merge以及rebase. 整合分支最容易的方法是merge,他会把两个分支的最新快照以及两者 ...

  9. LeetCode:二叉树的后序遍历【145】

    LeetCode:二叉树的后序遍历[145] 题目描述 给定一个二叉树,返回它的 后序 遍历. 示例: 输入: [1,null,2,3] 1 \ 2 / 3 输出: [3,2,1] 进阶: 递归算法很 ...

  10. 笔记-CSS空背景图片会导致页面被加载两次

    如果页面样式的背景图片路径设置为'' 或 '#', 会导致页面被重复加载两次 (Chrome.56.0.2924.87 测试) 因为:空图片路径属性值,默认加载当前页面的URL作为图片路径 Safar ...