火题小战 C. 情侣?给我烧了!
火题小战 C. 情侣?给我烧了!
题目描述
有 \(n\) 对情侣来到电影院观看电影。在电影院,恰好留有 \(n\) 排座位,每排包含 \(2\) 个座位,共 \(2×n\) 个座位。
现在,每个人将会随机坐在某一个位置上,且恰好将这 \(2 × n\) 个座位坐满。
如果一对情侣坐在了同一排的座位上,那么我们称这对情侣是和睦的。
你的任务是求出共有多少种不同的就坐方案满足恰好有 \(k\) 对情侣是和睦的。
两种就坐方案不同当且仅当存在一个人在两种方案中坐在了不同的位置。不难发现,一共会有 \((2n)!\) 种不同的就坐方案。
由于结果可能较大,因此输出对 \(998244353\) 取模的结果。
输入格式
输入包含多组数据。
输入的第 \(1\) 行包含 \(1\) 个正整数 \(T\),表示数据的组数。
接下来 \(T\) 行,每行包含 \(2\) 个正整数 \(n,k\)。
输出格式
输出共 \(T\) 行。
对于每组输入数据,输出共 \(1\) 行,包含 \(1\) 个整数,表示恰好有 \(k\)对情侣和睦的就坐方案数。
输入输出样例
输入 #1
5
1 1
2 0
2 2
2333 666
2333333 1000000
输出 #1
2
16
8
798775522
300377435
说明/提示
对于 \(10 \%\) 的数据,满足 \(1 \leq T \leq 10, 1 \leq n \leq 5\)。
对于 40 % 的数据,满足 \(1 \leq n \leq 3 \times 10^3\)。
对于 \(100 \%\) 的数据,满足 \(1 \leq T \leq 2 \times 10^5, 1 \leq n \leq 5 \times 10^6\)。
分析
我们设 \(f[x]\) 为恰好有 \(x\) 对情侣都错开的方案数
我们考虑如何把其分解为子问题
首先我们可以从这 \(2x\) 个人中随意选取一个人
接下来我们再选取一个不能与他配对的人
总的方案数为 \(2x(2x-2)\)
对于我们选出的这两个人的配偶,如果我们把他们也强制配对的话那么这相当于一个规模为 \(x-2\) 的子问题,同时我们还要乘上 \(x-1\) 代表在剩下的 \(x-1\) 行中选出一行给他们坐,他们还可以交换位置,所以还要乘 \(2\)
如果我们不给他们强制配对的话,那么这就是一个规模为 \(x-1\) 的子问题
初始化 \(f[0]=1, f[1]=0\)
转移方程 \(f[x]=2x(2x-2)(f[x-1]+2(x-1)f[x-2])\)
我们考虑了恰好有 \(k\) 对情侣错开的的情况,下面要考虑本题的求解,即恰好有 \(k\)对情侣和睦的就坐方案数
首先我们要在 \(n\) 对情侣中选出 \(k\) 对情侣和睦,还要在 \(n\) 排座位中选出 \(k\) 排让他们坐,每对情侣在这 \(k\) 排可以随便坐,情侣两人也可以互换位置
因此最终的结果为
\]
代码
#include<bits/stdc++.h>
using namespace std;
const int mod=998244353;
const int maxn=5e6+5;
int ny[maxn],jc[maxn],jcc[maxn],f[maxn];
long long ksm(int ds,int zs){
long long ans=1;
while(zs){
if(zs&1) ans=ans*ds%mod;
ds=(long long)ds*ds%mod;
zs>>=1;
}
return ans%mod;
}
signed main(){
ny[1]=1;
for(int i=2;i<maxn;i++){
ny[i]=((long long)mod-mod/i)*ny[mod%i]%mod;
}
jc[0]=1,jcc[0]=1;
for(int i=1;i<maxn;i++){
jc[i]=(long long)jc[i-1]*i%mod;
jcc[i]=(long long)jcc[i-1]*ny[i]%mod;
}
f[0]=1,f[1]=0;
for(int i=2;i<maxn;i++){
f[i]=(long long)2*i*(2*i-2)%mod*((long long)f[i-1]%mod+(long long)(2*i-2)*f[i-2]%mod)%mod;
}
int t;
scanf("%d",&t);
while(t--){
int n,k;
scanf("%d%d",&n,&k);
long long ans=(long long)jc[n]*jcc[k]%mod*jcc[n-k]%mod*jc[n]%mod*jcc[n-k]%mod*ksm(2,k)%mod*f[n-k]%mod;
printf("%lld\n",ans%mod);
}
return 0;
}
火题小战 C. 情侣?给我烧了!的更多相关文章
- # 火题小战 A.玩个球
火题小战 A.玩个球 题目描述 给你 \(n\) 种颜色的球,每个球有 \(k\) 个,把这 \(n\times k\) 个球排成一排,把每一种颜色的最左边出现的球涂成白色(初始球不包含白色),求有多 ...
- 火题小战 B. barbeque
火题小战 B. barbeque 题目描述 \(Robbery\) 是一个大吃货(雾) 某个神奇的串由牛肉和青椒构成,于是\(Robbery\)购买了\(n\)个餐包来自己做这个串,每个餐包中有一些牛 ...
- [编程题] 小易喜欢的数列 dp
https://www.nowcoder.com/question/next?pid=6291726&qid=112729&tid=12736753 [编程题] 小易喜欢的数列 时间限 ...
- YTU 2960: 改错题--小鼠标,你要干什吗?
2960: 改错题--小鼠标,你要干什吗? 时间限制: 1 Sec 内存限制: 128 MB 提交: 118 解决: 62 题目描述 鼠标双击不同的图标产生不同的效果,比如双击文档(documen ...
- 从乐视和小米“最火电视”之战 看PR传播策略
今年的双11够热闹.一方面,阿里.京东.国美.苏宁等电商巨头卯足了劲儿.试图在双11期间斗个你死我活,剑拔弩张的气势超过了以往不论什么一场双11:还有一方面.不少硬件厂商.家电企业也来凑双11 ...
- 火题大战Vol.1 A.
火题大战Vol.1 A. 题目描述 给定两个数\(x\),\(y\),比较\(x^y\) 与\(y!\)的大小. 输入格式 第一行一个整数\(T\)表示数据组数. 接下来\(T\)行,每行两个整数\( ...
- 火题大战Vol.0 B 计数DP
火题大战Vol.0 B 题目描述 \(n\) 个沙茶,被编号 \(1\)~$ n$.排完队之后,每个沙茶希望,自己的相邻的两人只要无一个人的编号和自己的编号相差为 \(1\)(\(+1\) 或\(-1 ...
- 快速入门PaddleOCR,并试用其开发一个搜题小工具
介绍 PaddleOCR 是一个基于百度飞桨的OCR工具库,包含总模型仅8.6M的超轻量级中文OCR,单模型支持中英文数字组合识别.竖排文本识别.长文本识别.同时支持多种文本检测.文本识别的训练算法. ...
- H5版俄罗斯方块(4)---火拼对战的雏形
前言: 勿忘初心, 本系列的目标是实现一款类似QQ"火拼系列"的人机对战版俄罗斯方块. 在完成了基本游戏框架和AI的算法探索后, 让我们来尝试一下人机大战雏形编写. 本系列的文章链 ...
随机推荐
- 围绕一个 volatile 关键字居然可以问出来 16 个问题
对于 Java 每次面试就会想到多线程,多线程问题基本跑不了要问一下 volalite 关键字,可是我万万没想到居然一个 volatile 关键字可以连续问题出来 16 个问题!看下你能回答出来几个? ...
- Linux好学吗?怎么自学Linux?6个值得你去学习Linux的理由!
两个多月前,我对日常工作做出了一个非常重要的决定-我决定从Windows切换到Linux,将其作为个人和办公笔记本电脑的主要系统.除了开始时一些小的驱动程序问题之外,切换非常平稳,我不会考虑返回.如果 ...
- 详解Vue大护法——组件
1.什么是组件化 人面对复杂问题的处理方式: 任何一个人处理信息的逻辑能力都是有限的 所以,当面对一个非常复杂的问题时,我们不太可能一次性搞定一大堆的内容. 但是,我们人有一种天生的能力,就是将问题进 ...
- wpf文字模糊
wpf如果使用了DropShadowEffect,会导致文字模糊,可以在window上设置 this.UseLayoutRounding = true;解决此问题
- APP自动化 -- 获取driver
一.appium设置 1.打开appium 2.设置 appium服务器:点击 高级设置 3.启动 appium 服务器 二.查看 .apk 安装包的“包名”和“活动入口名” 1.先复制本地 ...
- web自动化 -- 三种等待方式
一.强制等待 二.隐式等待 注:隐式等待的作用域是全局,所以一般设置在整局代码的头几行. 如: 三.显示等待 元素存在: 元素可见: 元素可点击: 看到上图源码中有一个 element.is_en ...
- python xpath的基本用法
XPath是一种在XML文档中查找信息的语言,使用路径表达式在XML文档中进行导航.学习XPath需要对XML和HTML有基本的了解. 在XPath中,有七种类型的节点:文档(根)节点.元素.属性.文 ...
- 【Laravel】为Eloquent 模型设置全局作用域和局部作用域进行查询
全局作用域 所谓「全局作用域」,指的是预置过滤器在注册该「全局作用域」的模型类的所有查询中生效,不需要指定任何额外条件. 以 User 模型类为例,我们在系统中可能只想针对已经验证过邮箱的用户进行操作 ...
- XML--概念、约束、解析
概念 XML:可扩展标记语言 HTML:超文本标记语言 两者的区别: 1.语法结构类似,单语法要求不同 HTML不区分大小写,XML严格区分大小写 在HTML中,有时不严格,如果上下文清楚地显示出段落 ...
- Arduino+温度、湿度传感器
Arduino语言注解Arduino语言是建立在C/C++基础上的,其实也就是基础的C语言,Arduino语言只不过把AVR单片机(微控制器)相关的一些参数设置都函数化,不用我们去了解他的底层,让我们 ...