news 2026/4/15 5:59:29

《P4071 [SDOI2016] 排列计数》

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《P4071 [SDOI2016] 排列计数》

题目描述

求有多少种 1 到 n 的排列 a,满足序列恰好有 m 个位置 i,使得 ai​=i。

答案对 109+7 取模。

输入格式

本题单测试点内有多组数据

输入的第一行是一个整数 T,代表测试数据的组数。

以下 T 行,每行描述一组测试数据。

对于每组测试数据,每行输入两个整数,依次代表 n 和 m。

输出格式

共输出 T 行,对于每组测试数据,输出一行一个整数代表答案。

输入输出样例

输入 #1复制

5 1 0 1 1 5 2 100 50 10000 5000

输出 #1复制

0 1 20 578028887 60695423

说明/提示

数据规模与约定

本题共 20 个测试点,各测试点等分,其数据规模如下表。

测试点编号T=n,m≤测试点编号T=n,m≤
1∼3103810∼12103103
4∼61031213∼145×105103
7∼910310015∼205×105106

对于全部的测试点,保证 1≤T≤5×105,1≤n≤106,0≤m≤106。

代码实现:

#include<cstdio> #include<cstring> #include<algorithm> #include<cmath> #define ll long long using namespace std; const int N=1010101; const ll mod=1e9+7; ll t, n, m, inv[N], fac[N], pt[N], res; ll qpow(ll x, ll y) { res = 1; while(y > 0) { if(y % 2) res = (res * (x % mod)) % mod; x = ((x % mod) * (x % mod)) % mod; y >>= 1; } return res; } int main() { inv[0] = 1; inv[1] = 1; pt[0] = 1; pt[2] = 1; pt[3] = 2; fac[1] = 1; for(int i=2; i<=N; ++i) fac[i] = ((fac[i-1] % mod) * (i % mod)) % mod; for(int i=4; i<=N; ++i) if(i%2 == 0) pt[i] = ((pt[i-1] % mod * i % mod) % mod + 1) % mod; else pt[i] = ((pt[i-1] % mod * i % mod) % mod - 1 + mod) % mod; inv[N] = qpow(fac[N], mod-2); for(ll i=N; i>=2; --i) inv[i-1] = ((inv[i] % mod) * i) % mod; scanf("%lld", &t); while(t--) { scanf("%lld%lld", &n, &m); printf("%lld\n", (((fac[n] % mod * inv[n-m] % mod) % mod * inv[m] % mod) % mod * pt[n-m] % mod) % mod); } return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 22:59:30

玩转Java Map集合,从基础到实战的全面解析

在Java集合框架中&#xff0c;Map是与Collection并列的核心接口&#xff0c;它以**键值对&#xff08;Key-Value&#xff09;**的形式存储数据&#xff0c;是开发中处理映射关系的必备工具。不管是日常业务开发中的数据缓存、配置存储&#xff0c;还是复杂的业务逻辑映射&#…

作者头像 李华
网站建设 2026/4/8 21:24:17

【C/C++】C语言内存函数

memcpy使用和模拟实现memcpy可以代替strcpy代码语言&#xff1a;javascriptAI代码解释void * memcpy ( void * destination, const void * source, size_t num );//void*来接受任意指针,size_t 单位是字节 //memcpy的头文件为<string.h> mem是memory的缩写 是内存的意思…

作者头像 李华
网站建设 2026/4/13 11:00:49

【C/C++】字符函数和字符串函数

字符函数和字符串函数1.字符分类函数C语⾔中有⼀系列的函数是专⻔做字符分类的&#xff0c;也就是⼀个字符是属于什么类型的字符的。 这些函数的使⽤都需要包含⼀个头⽂件是 ctype.h在这里插入图片描述这些函数的使⽤⽅法⾮常类似&#xff0c;我们就讲解⼀个函数的事情&#xf…

作者头像 李华
网站建设 2026/4/11 15:23:21

【C/C++】深入理解指针(一)

1.1 内存在讲内存和地址之前&#xff0c;我们想有个⽣活中的案例&#xff1a; 假设有⼀栋宿舍楼&#xff0c;把你放在楼⾥&#xff0c;楼上有100个房间&#xff0c;但是房间没有编号&#xff0c;你的⼀个朋友来找你玩&#xff0c; 如果想找到你&#xff0c;就得挨个房⼦去找&am…

作者头像 李华
网站建设 2026/4/14 15:09:39

PyTorch-CUDA-v2.6镜像部署Flask API对外提供模型服务

PyTorch-CUDA-v2.6 镜像部署 Flask API 对外提供模型服务 在深度学习模型从实验室走向生产环境的过程中&#xff0c;一个常见但棘手的问题是&#xff1a;为什么训练好的模型一到线上就“水土不服”&#xff1f; 可能是依赖版本不一致、GPU 环境缺失、CUDA 编译失败&#xff0c;…

作者头像 李华
网站建设 2026/4/15 12:09:46

CSS3 新增文本属性

一、文本阴影二、文本换行三、文本溢出四、文本修饰

作者头像 李华