Codeforces 559C Gerald and Giant Chess【组合数学】【DP】
题目大意
有一个wxh的网格,上面有n个黑点,问你从(1,1)走到(w,h)不经过任何黑点的方案数
思路
考虑容斥
先把所有黑点按照x值进行排序方便计算
\(dp_{i}\)表示从起点走到第i个黑点不经过任何的黑点的方案数
然后\(dp_{i}=C(x_i+y_i-2,x_i-1)-\sum_{j|x_j\leq x_i,y_j\leq y_i}dp_{j}\times C(j->i)\)
这样容斥为什么是正确的,\(dp_{j}\)考虑了所有经过j的情况,其他的包含j的点都不会考虑j的贡献
所以容斥是正确的
//Author: dream_maker
#include<bits/stdc++.h>
using namespace std;
//----------------------------------------------
//typename
typedef long long ll;
//convenient for
#define fu(a, b, c) for (int a = b; a <= c; ++a)
#define fd(a, b, c) for (int a = b; a >= c; --a)
#define fv(a, b) for (int a = 0; a < (signed)b.size(); ++a)
//inf of different typename
const int INF_of_int = 1e9;
const ll INF_of_ll = 1e18;
//fast read and write
template <typename T>
void Read(T &x) {
  bool w = 1;x = 0;
  char c = getchar();
  while (!isdigit(c) && c != '-') c = getchar();
  if (c == '-') w = 0, c = getchar();
  while (isdigit(c)) {
    x = (x<<1) + (x<<3) + c -'0';
    c = getchar();
  }
  if (!w) x = -x;
}
template <typename T>
void Write(T x) {
  if (x < 0) {
    putchar('-');
    x = -x;
  }
  if (x > 9) Write(x / 10);
  putchar(x % 10 + '0');
}
//----------------------------------------------
const int N = 2e5 + 10;
const int Mod = 1e9 + 7;
int fac[N], inv[N];
int w, h, n, dp[N];
//dp表示不经过任何黑点走到第i个黑点的方案数
struct Point {
  int x, y;
} p[N];
bool cmp(Point a, Point b) {
  return a.x == b.x ? a.y < b.y : a.x < b.x;
}
int add(int a, int b) {
  return (a += b) >= Mod ? a - Mod : a;
}
int sub(int a, int b) {
  return (a -= b) < 0 ? a + Mod : a;
}
int mul(int a, int b) {
  return 1ll * a * b % Mod;
}
int fast_pow(int a, int b) {
  int res = 1;
  while (b) {
    if (b & 1) res = mul(res, a);
    a = mul(a, a);
    b >>= 1;
  }
  return res;
}
int C(int a, int b) {
  return mul(fac[a], mul(inv[b], inv[a - b]));
}
void init(int len) {
  fac[0] = inv[0] = 1;
  fu(i, 1, len) fac[i] = mul(fac[i - 1], i);
  fu(i, 1, len) inv[i] = fast_pow(fac[i], Mod - 2);
}
int main() {
  Read(h), Read(w), Read(n);
  init(h + w);
  fu(i, 1, n) Read(p[i].x), Read(p[i].y);
  sort(p + 1, p + n + 1, cmp);
  fu(i, 1, n) {
    dp[i] = C(p[i].x + p[i].y - 2, p[i].x - 1);
    fu(j, 1, i - 1)
      if (p[j].y <= p[i].y)
        dp[i] = sub(dp[i], mul(dp[j], C(p[i].x - p[j].x + p[i].y - p[j].y, p[i].x - p[j].x)));
  }
  int ans = C(h + w - 2, h - 1);
  fu(i, 1, n) ans = sub(ans, mul(dp[i], C(h - p[i].x + w - p[i].y, h - p[i].x)));
  Write(ans);
  return 0;
}
Codeforces 559C Gerald and Giant Chess【组合数学】【DP】的更多相关文章
- CodeForces 559C Gerald and Giant Chess
		C. Gerald and Giant Chess time limit per test 2 seconds memory limit per test 256 megabytes input st ... 
- codeforces(559C)--C. Gerald and Giant Chess(组合数学)
		C. Gerald and Giant Chess time limit per test 2 seconds memory limit per test 256 megabytes input st ... 
- Codeforces Round #313 (Div. 2) E. Gerald and Giant Chess (Lucas + dp)
		题目链接:http://codeforces.com/contest/560/problem/E 给你一个n*m的网格,有k个坏点,问你从(1,1)到(n,m)不经过坏点有多少条路径. 先把这些坏点排 ... 
- 2018.11.07 codeforces559C. Gerald and Giant Chess(dp+组合数学)
		传送门 令f[i]f[i]f[i]表示对于第iii个棋子,从(1,1)(1,1)(1,1)出发到它不经过其它棋子的方案数. 于是我们假设(h,w)(h,w)(h,w)有一个棋子,求出它的fff值就可以 ... 
- CF 559C - Gerald and Giant Chess (组合计数)
		\(C_{x+y}^y\)的公式,DP容斥删多余贡献. #include <cstdio> #include <iostream> #include <cstring&g ... 
- CodeForces 540E - Gerald and Giant Chess(数论)
		给一个棋盘,需要从左上角走到右下角,有部分点不能走,求一共有多少种走法. 首先要知道从一个点A到另一个点B在没有障碍下有多少种走法.保证A在B的左上方,如图 一共需要走(X+Y)步(图中△x,△y), ... 
- dp - Codeforces Round #313 (Div. 1) C. Gerald and Giant Chess
		Gerald and Giant Chess Problem's Link: http://codeforces.com/contest/559/problem/C Mean: 一个n*m的网格,让你 ... 
- Codeforces Round #313 (Div. 1) C. Gerald and Giant Chess DP
		C. Gerald and Giant Chess Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest ... 
- CodeForces 559C Gerald and Gia (格路+容斥+DP)
		CodeForces 559C Gerald and Gia 大致题意:有一个 \(N\times M\) 的网格,其中有些格子是黑色的,现在需要求出从左上角到右下角不经过黑色格子的方案数(模 \(1 ... 
随机推荐
- nginx web服务器详解1(转)
			原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://freeloda.blog.51cto.com/2033581/1285332 大 ... 
- UVa 11149 矩阵的幂(矩阵倍增法模板题)
			https://vjudge.net/problem/UVA-11149 题意: 输入一个n×n矩阵A,计算A+A^2+A^3+...A^k的值. 思路: 矩阵倍增法. 处理方法如下,一直化简下去直到 ... 
- 创建Jmeter中使用的jar包中的工具类方法
			1. 在IDEA中新建一个maven工程. 2. 编写工具类方法,如加密算法.此处以加法为例. package DemoTest; public class DemoClass{ public int ... 
- nodejs中mysql断线重连
			之前写了个小程序Node News,用到了MySQL数据库,在本地测试均没神马问题.放上服务器运行一段时间后,偶然发现打开页面的时候页面一直处于等待状态,直到Nginx返回超时错误.于是上服务器检查了 ... 
- Android自定义view-CircleSeekbar
			自定义view练手,效果图如下:实现功能 可设置圆环颜色和线宽及触摸后的颜色和线宽 可设置圆环内圈显示的文本内容及字体大小.颜色 可设置触摸点的图片 可设置触摸的有效范围 源码git ... 
- Tomcat中session共享问题的简单解决办法
			tomcat-redis-session-manager 使用redis配置tomcat共享session 结构图: 分析: 分布式web server集群部署后需要实现session共享,针对 to ... 
- IOS-下载动画
			就2小时教会你抽丝剥茧CAAnimation核心动画之精美的下载动画 header 设计灵感 设计此效果的作者 Nick; images 开始之前你需要了解的 先上一张CAAnimation层次图: ... 
- 008PHP基础知识——运算符(一)
			<?php /** * 运算符(一) */ /*PHP中的运算符: * 1.算术运算符: * 2.递增/递减运算符 * 3.比较运算符 * 4.逻辑运算符 * 5.位运算符 * 6.其他运算符 ... 
- 快速求排列组合 lucas定理
			对于C(n, m) mod p.这里的n,m,p(p为素数)都很大的情况. 就不能再用C(n, m) = C(n - 1,m) + C(n - 1, m - 1)的公式递推了. 一般lucas定理的p ... 
- Markdown_04_折叠语法
			目录 一.折叠语法 参考资料 一.折叠语法 主要使用的是 html5的 details标签 (1)示例如下: <details> <summary>折叠文本</summa ... 
