[ AGC001 E ] BBQ Hard
2021/4/26 18:56:56
本文主要是介绍[ AGC001 E ] BBQ Hard,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目
Atcoder
思路
代码
#include <iostream> #include <cstring> #include <algorithm> #define int long long using namespace std; const int N = 4030, M = 200010, D = 2010, mod = 1e9 + 7; int n, m, f[N][N], fact[N << 1], invf[N << 1]; int A[M], B[M]; int qmi(int a, int b) { int res = 1; for (; b; b >>= 1, a = a * a % mod) if (b & 1) res = a * res % mod; return res % mod; } int inv(int x) { return qmi(x, mod - 2); } int C(int a, int b) { return fact[a] * invf[b] % mod * invf[a - b] % mod; } signed main() { cin >> n; for (int i = 1; i <= n; i++) // 防止数组越界加个偏移量 D cin >> A[i] >> B[i], f[D - A[i]][D - B[i]]++; for (int i = 1; i < N; i++) for (int j = 1; j < N; j++) f[i][j] = (f[i][j] + (f[i - 1][j] + f[i][j - 1]) % mod) % mod; fact[0] = 1, invf[0] = inv(1); for (int i = 1; i <= 8000; i++) fact[i] = fact[i - 1] * i % mod, invf[i] = inv(fact[i]); int res = 0; for (int i = 1; i <= n; i++) { res = (res + f[D + A[i]][D + B[i]]) % mod; res = ((res - C(2 * A[i] + 2 * B[i], 2 * A[i])) % mod + mod) % mod; } cout << res * inv(2) % mod << endl; return 0; }
这篇关于[ AGC001 E ] BBQ Hard的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-06-30uniAPP 实现全屏左右滚动滚动的效果-icode9专业技术文章分享
- 2024-06-30如何在本地使用授权或插件-icode9专业技术文章分享
- 2024-06-30伪静态规则配置方法汇总-icode9专业技术文章分享
- 2024-06-29易优CMS安装常见问题汇总-icode9专业技术文章分享
- 2024-06-28易优新手必读安装教程-icode9专业技术文章分享
- 2024-06-28忘记eyoucms后台密码怎么办?-icode9专业技术文章分享
- 2024-06-26终极指南:Scrum中如何设置需求优先级
- 2024-06-26AI大模型企业应用实战(25)-为Langchain Agent添加记忆功能
- 2024-06-26小白家庭 nas 搭建方案-icode9专业技术文章分享
- 2024-06-23AI大模型企业应用实战(14)-langchain的Embedding