当前位置: 首页 > news >正文

AtCoder [ABC156E] Roaming


题目传送门


前言

每次在做数学的时候(尤其是组合排列),都深深地感受到一种无力感 . . . . . . ...... ......一种看完题解感觉自己跟傻*一样地无力感 . . . . . . ...... ......


思路

我们先考虑最多会剩下多少个空房间:
k k k 个人各向左走一步就会剩下 k k k 个空房间,但是由于 k k k 可能大于等于 n n n,所以 k k k 要与 n − 1 n - 1 n1 m i n min min
然后我们枚举剩下 i i i 个空房间, i ∈ [ 0 , m i n ( k , n − 1 ) ] i \in [0, min(k, n - 1)] i[0,min(k,n1)],每个有 C n i C_n^i Cni 种选择。

然后就是把 n n n 个人划分到 n − i n - i ni 个房间里的可能数:
这就相当于在 n n n无差别的人之间插入隔板,将其分成 n − i n - i ni 个非空集合,就有 C n − 1 n − i − 1 C_{n - 1}^{n - i - 1} Cn1ni1 种可能。

所以一共就有: ∑ i = 0 m i n ( k , n − 1 ) C n i × C n − 1 n − i − 1 \sum_{i = 0} ^ {min(k, n - 1)} C_n^i \times C_{n - 1} ^ {n - i - 1} i=0min(k,n1)Cni×Cn1ni1 种可能。


代码

#include <bits/stdc++.h>

using namespace std;

typedef long long ll;

const int maxn = 2e5 + 7;
const int mod  = 1e9 + 7;

ll n, k, ans;
ll fac[maxn], inv[maxn];
ll qpow(ll x, ll y) {
	ll res = 1;
	for (; y; y >>= 1, x = x * x % mod)
		if (y & 1) res = res * x % mod;
	return res;
}
ll C(ll x, ll y) {return fac[x] * inv[x - y] % mod * inv[y] % mod;}
int main() {
	scanf("%lld%lld", &n, &k);
	fac[0] = inv[0] = 1;
	for (ll i = 1; i <= n; ++i) {
		fac[i] = fac[i - 1] * i % mod;
		inv[i] = qpow(fac[i], mod - 2);
	}
	for (int i = 0; i <= min(k, n - 1); ++i)
		ans = (ans + C(n, i) * C(n - 1, i) % mod) % mod;  // C(n - 1, n - i - 1) = C(n - 1, i)
	printf("%lld\n", ans);
	return 0;
} 
http://www.dtcms.com/a/85923.html

相关文章:

  • Vue.js 组件开发全解析:从基础概念到实战应用
  • leeCode 70. 爬楼梯
  • Java单例模式中的饿汉模式和懒汉模式
  • 使用ES支持树状结构查询实战
  • SQLite 查询数据库属性
  • 一道积分_3
  • Linux多线程
  • Java 大视界 -- 基于 Java 的大数据机器学习模型的可扩展性设计与实践(149)
  • 使用 Python 开发 MCP Server 及 Inspector 工具详解
  • 【2025 华中师范大学-菜鸟杯程序设计竞赛】部分题解
  • 多模态工作idea讨论
  • HTTPS协议—加密算法和中间攻击人的博弈
  • 【Dive Into Stable Diffusion v3.5】2:Stable Diffusion v3.5原理介绍
  • Baklib驱动企业数字化内容管理升级
  • WebSocket接入SSL证书
  • Java面试黄金宝典11
  • 数据库锁机制
  • 《Oracle DBA入门实战:十大高频问题详解与避坑指南》
  • 智能飞鸟监测 守护高压线安全
  • 使用 Go 构建 MCP Server
  • 【yolo11自定义实例分割训练集教程】
  • 2.2.盈亏平衡分析
  • webstorm调试模式报错:Cannot detect a launch configuration
  • 快速入手:Nacos融合SpringCloud成为注册配置中心
  • MySQL 入门大全:常用函数
  • Flink启动任务
  • LVS的 NAT 模式实现 3 台RS的轮询访问
  • 【IntelliJ IDEA快速绑定Maven配置指南】
  • 2025年3月23日坚持写原创的第24天
  • 华为HCIE网络工程师培训选机构攻略