博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
bzoj-4517 4517: [Sdoi2016]排列计数(组合数学)
阅读量:4654 次
发布时间:2019-06-09

本文共 1384 字,大约阅读时间需要 4 分钟。

题目链接:

Time Limit: 60 Sec  Memory Limit: 128 MB
Submit: 846  Solved: 530
[][][]

Description

求有多少种长度为 n 的序列 A,满足以下条件:
1 ~ n 这 n 个数在序列中各出现了一次
若第 i 个数 A[i] 的值为 i,则称 i 是稳定的。序列恰好有 m 个数是稳定的
满足条件的序列可能很多,序列数对 10^9+7 取模。

Input

第一行一个数 T,表示有 T 组数据。
接下来 T 行,每行两个整数 n、m。
T=500000,n≤1000000,m≤1000000
 

Output

输出 T 行,每行一个数,表示求出的序列数

 

Sample Input

5
1 0
1 1
5 2
100 50
10000 5000

Sample Output

0
1
20
578028887
60695423
 
题意:
 
思路:
 
我们很容易知道方案数是C(n,m)*dp[n-m];
dp[n]表示n的错排数;递推公式是dp[n]=(n-1)*(dp[n-1]+dp[n-2])=n*dp[n-1]+(-1)
n ;
 
AC代码:
/**************************************************************    Problem: 4517    User: LittlePointer    Language: C++    Result: Accepted    Time:11108 ms    Memory:16916 kb****************************************************************/ #include 
using namespace std;typedef long long LL;const LL mod=1e9+7;const int maxn=1e6+10;LL dp[maxn],p[maxn];inline void init(){ dp[0]=1;dp[1]=0;dp[2]=1;p[1]=1;p[2]=2;p[0]=1; for(int i=3;i
>=1; } return s;}int main(){ //freopen("in.txt","r",stdin); init(); int t,n,m; scanf("%d",&t); while(t--) { scanf("%d%d",&n,&m); if(m>n){puts("0");continue;} LL ans=p[n]*dp[n-m]%mod,temp=p[m]*p[n-m]%mod; ans=ans*pow_mod(temp,mod-2)%mod; printf("%lld\n",ans); } return 0;}

  

 

转载于:https://www.cnblogs.com/zhangchengc919/p/5983049.html

你可能感兴趣的文章
MySQL
查看>>
HTTP/2 和 Websocket
查看>>
hdu 2050 折线分割平面
查看>>
[翻译svg教程]svg 中的g元素
查看>>
普通类中能不能有函数模板?/有函数模板的类可以是普通类吗
查看>>
表单输入绑定
查看>>
python学习日记(迭代器、生成器)-乱七八糟
查看>>
ADO.NET数据集的工作原理
查看>>
oracle实现自增长列
查看>>
自我介绍
查看>>
前端组件化
查看>>
转载:C# this.Invoke()的作用与用法 理解三
查看>>
邮件模板——开发篇
查看>>
我和我的广告前端代码(三):一次重来的机会,必要的技术选型
查看>>
react--绑定this三种方式
查看>>
js + css 实现标签内容切换功能
查看>>
做接口自动化时候,一些登录头信息可以通过aop的方式进行增强
查看>>
linux popen函数
查看>>
《OpenGL编程指南》学习进度备忘
查看>>
关于 C# 中 Events 和 Thread Safety
查看>>