CF1237F Balanced Domino Placements

Solution

显然可以先考虑横着的骨牌,再考虑竖着的骨牌。但是思路卡在了选取横着的骨牌会对竖着的骨牌的相邻对数产生影响。

然而事实上我们只需要换一个统计顺序,先考虑横着的骨牌的列和竖着的骨牌的行,然后再考虑横着的骨牌的行和竖着的骨牌的列(因为单行/列没有双行/列的必须相邻的限制,因此可以简单地通过剩余行/列数统计)。

前面一项可以简单地dpdpdp得到,后面一项组合计数即可。

时间复杂度O(n2)O(n^2)O(n2)。

Code

#include <bits/stdc++.h>using namespace std;template<typename T> inline bool upmin(T &x, T y) { return y < x ? x = y, 1 : 0; }
template<typename T> inline bool upmax(T &x, T y) { return x < y ? x = y, 1 : 0; }#define MP(A,B) make_pair(A,B)
#define PB(A) push_back(A)
#define SIZE(A) ((int)A.size())
#define LEN(A) ((int)A.length())
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define fi first
#define se secondtypedef long long ll;
typedef unsigned long long ull;
typedef long double lod;
typedef pair<int, int> PR;
typedef vector<int> VI; const lod eps = 1e-11;
const lod pi = acos(-1);
const int mods = 998244353;
const int oo = 1 << 30;
const ll loo = 1ll << 62;
const int MAXN = 4005;
const int INF = 0x3f3f3f3f;//1061109567
/*--------------------------------------------------------------------*/
inline int read() {int f = 1, x = 0; char c = getchar();while (c < '0' || c > '9') { if (c == '-') f = -1; c = getchar(); }while (c >= '0' && c <= '9') { x = (x << 3) + (x << 1) + (c ^ 48); c = getchar(); }return x * f;
}
int tagx[MAXN], tagy[MAXN], fn[MAXN][MAXN], fm[MAXN][MAXN], fac[MAXN], inv[MAXN];
int upd(int x , int y) { return x + y >= mods ? x + y - mods : x + y; }
int C(int x, int y) { return x < y ? 0 :1ll * fac[x] * inv[y] % mods * inv[x - y] % mods; }
int quick_pow(int x, int y) {int ret = 1;for(; y ; y >>= 1) {if (y & 1) ret = 1ll * ret * x % mods;x = 1ll * x * x % mods;}return ret;
}
void Init(int n) {fac[0] = 1;for (int i = 1; i <= n ; ++ i) fac[i] = 1ll * fac[i - 1] * i % mods;inv[n] = quick_pow(fac[n], mods - 2);for (int i = n - 1; i >= 0 ; -- i) inv[i] = 1ll * inv[i + 1] * (i + 1) % mods;
}
signed main() {int n = read(), m = read(), k = read();Init(max(n, m));for (int i = 1; i <= k ; ++ i) tagx[read()] = 1, tagy[read()] = 1, tagx[read()] = 1, tagy[read()] = 1;fn[0][0] = 1;for (int i = 1; i <= n ; ++ i)for (int j = 0; j * 2 <= i; ++ j) fn[i][j] = (i > 1 && !tagx[i] && !tagx[i - 1]) ? upd(fn[i - 1][j], fn[i - 2][j - 1]) : fn[i - 1][j];fm[0][0] = 1;for (int i = 1; i <= m ; ++ i)for (int j = 0; j * 2 <= i; ++ j) fm[i][j] = (i > 1 && !tagy[i] && !tagy[i - 1]) ? upd(fm[i - 1][j], fm[i - 2][j - 1]) : fm[i - 1][j];int rn = 0, rm = 0;for (int i = 1; i <= n ; ++ i) rn += !tagx[i];for (int i = 1; i <= m ; ++ i) rm += !tagy[i];int ans = 0;for (int i = 0; i * 2 <= rn ; ++ i)for (int j = 0; j * 2 <= rm; ++ j) ans = upd(ans, 1ll * fac[i] * fac[j] % mods * C(rm - j * 2, i) % mods * C(rn - i * 2, j) % mods * fn[n][i] % mods * fm[m][j] % mods);printf("%d\n", ans);return 0;
}

CF1237F Balanced Domino Placements(组合计数,dp)相关推荐

  1. CF1237F Balanced Domino Placements(dp+组合计数)

    CF1237F Balanced Domino Placements problem solution code problem 题目链接 solution 骨牌横着放会占用一行两列,骨牌竖着放会占用 ...

  2. Educational Codeforces Round 81 (Rated for Div. 2) F.Good Contest \ 洛谷 划艇 组合 计数dp

    cf传送门 P3643 [APIO2016]划艇 文章目录 题意: 思路: 题意: aia_iai​在[li,ri][l_i,r_i][li​,ri​]等概率随机选一个数,求aaa数组不增的概率. 思 ...

  3. bzoj2111,P2606-[ZJOI2010]排列计数【Lucas,组合计数,dp】

    正题 题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id=2111 https://www.luogu.org/problem/P2606 题 ...

  4. Sumsets POJ - 2229(计数dp)

    题意: 给一个数,是集合的总数和,集合元素只能为2的次幂数,问这样的集合有多少? 题目: Farmer John commanded his cows to search for different ...

  5. 数学知识——组合计数

    组合计数 文章目录 组合计数 概述 动态规划 牡牛和牝牛 思路 代码 隔板法 方程的解 思路 代码 序列统计 思路 代码 加法 & 乘法原理 加法原理 乘法原理 车的摆放 思路 代码 容斥原理 ...

  6. 解题报告(五)组合计数(ACM / OI)超高质量题解

    繁凡出品的全新系列:解题报告系列 -- 超高质量算法题单,配套我写的超高质量题解和代码,题目难度不一定按照题号排序,我会在每道题后面加上题目难度指数(1∼51 \sim 51∼5),以模板题难度 11 ...

  7. 解题报告(二)E、(BZOJ3513) [MUTC2013] idiots(生成函数 + FFT + 组合计数)

    繁凡出品的全新系列:解题报告系列 -- 超高质量算法题单,配套我写的超高质量题解和代码,题目难度不一定按照题号排序,我会在每道题后面加上题目难度指数(1∼51 \sim 51∼5),以模板题难度 11 ...

  8. UVA 10564 计数DP

    也是经典的计数DP题,想练练手,故意不写记忆化搜索,改成递推,还是成功了嘞...不过很遗憾一开始WA了,原来是因为判断结束条件写个 n或s为0,应该要一起为0的,搞的我以为自己递推写挫了,又改了一下, ...

  9. 【Luogu4921】情侣?给我烧了!(组合计数)

    [Luogu4921]情侣?给我烧了!(组合计数) 题面 洛谷 题解 很有意思的一道题目. 直接容斥?怎么样都要一个平方复杂度了. 既然是恰好\(k\)对,那么我们直接来做: 首先枚举\(k\)对人出 ...

最新文章

  1. 烂泥:CentOS6.5挂载windows共享文件夹
  2. 珂朵莉的约数(牛客练习赛9)
  3. bootstratp图标的使用
  4. sap把系统内部直接写入到自建表_特斯拉放弃SAP后,仅四个月就开发了套ERP
  5. 丢弃Git中的本地提交
  6. matlab 稀疏矩阵(sparse matrix)
  7. Andrew Ng(coursera)单变量线性回归(LINEAR REGRESSION WITH ONE VARIABLE)
  8. matlab 矩阵维度一致,错误使用 / 矩阵维度必须一致。
  9. 小型bbs论坛系统开发1 需求分析
  10. 区块链架构1.0、2.0与3.0梳理
  11. 4.26,最好用的新浪图床GG了,博客满屏的403
  12. 成功爬虫下载抖音用户视频(无水印)
  13. 远程访问大华摄像头_通过WEB调用大华网络摄像头
  14. 在VC中用CMenuXP使应用程序拥有Office XP风格的界面
  15. 苏州大学 数据库题库
  16. 【运营】关于A/BTest的简单介绍
  17. 系统架构设计师备考经验分享:边听课边画思维导图,高效学习
  18. js-web前端-多语言切换-data-localize
  19. Web全栈开发1+x(中级)PHPMySQL知识
  20. 中国人民大学_《组织行为学》_14.相对剥夺:怎样快速形成凝聚力?

热门文章

  1. 现在的男生真的太惨了
  2. 【直观理解】一文搞懂RNN(循环神经网络)基础篇
  3. 机器学习没有想象中的那么难
  4. linux mint 用户管理,Linux Mint 新工具:将网站转变为独立的应用
  5. 英特尔傲腾内存linux,英特尔傲腾内存怎么样?intel傲腾内存优点和缺点你知道吗?...
  6. 小米8ios图标包下载_小米互传PC端抢先下载,免流量、高速互传,支持多设备共享...
  7. 如何在android客户端中做到自动检查数据更新?,UpdateHelper
  8. js堆和栈的区别_几个例子理解不同数据类型的堆栈内存处理
  9. Java秘技之Json数据解析与转换 -- Java使用示例
  10. lunixs 常用命令c语言,常用Lunix命令 - osc_271igh42的个人空间 - OSCHINA - 中文开源技术交流社区...