排列计数(permutation)

题目描述

求有多少种长度为n的序列A,满足以下条件:

1) 1~n这n个数在序列中各出现了一次

2) 若第i个数A[i]的值为i,则称i是稳定的。序列恰好有m个数是稳定的。

满足条件的序列可能很多,序列数对109+7取模。

输入

第一行一个数T,表示有T组数据。

接下来T行,每行两个整数n、m。

输出

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

样例输入

5
1 0
1 1
5 2
100 50
10000 5000

样例输出

0
1
20
578028887
60695423

提示

【数据规模与约定】

T=500000,n≤1000000,m≤1000000。

来源

SDOI2016 Round1 Day2


solution

此题求C(n,m)*f[n-m](f[i]表示i个数错排的方案)

我只会容斥求错排https://blog.csdn.net/liankewei123456/article/details/81563581

这题会T

公式:

啥意思

考虑新加入第i个数,如果与k互换 那么方案为f[i-2]

如果不是则为f[i-1]

这样的k有(i-1)个

注意 f[0]=1,f[1]=0,f[2]=1;

剩下的就是基础啦

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define maxn 1000005
#define mod 1000000007
using namespace std;
long long T,n,m,h[maxn],ny[maxn];
long long f[maxn];
long long lian(long long k,int num){
long long a=k,ans=1;
while(num>0){
if(num&1)ans=ans*a;
a=a*a;a%=mod;ans%=mod;num>>=1;
}
return ans;
}
long long C(int n,int m){
return (((h[n]*ny[m])%mod)*ny[n-m])%mod;
}
int main(){
h[0]=1;
n=1000000;
for(int i=1;i<=n;i++){h[i]=h[i-1]*i;h[i]%=mod;}
ny[n]=lian(h[n],mod-2);ny[0]=1;
for(int i=n-1;i>=1;i--){
ny[i]=ny[i+1]*(i+1);
ny[i]%=mod;
}
int op=1;
f[0]=1;f[1]=0;f[2]=1;
for(int i=3;i<=1000000;i++){
f[i]=((i-1)*((f[i-1]+f[i-2])%mod))%mod;
//if(i<=50)cout<<f[i]<<endl;
}
cin>>T;
while(T--){
scanf("%lld%lld",&n,&m);
long long tmp=C(n,m)*f[n-m];
tmp%=mod;
printf("%lld\n",tmp);
}
return 0;
}

排列计数(permutation)的更多相关文章

  1. ACM/ICPC 之 DP-浅谈“排列计数” (POJ1037)

    这一题是最近在看Coursera的<算法与设计>的公开课时看到的一道较难的DP例题,之所以写下来,一方面是因为DP的状态我想了很久才想明白,所以借此记录,另一方面是看到这一题有运用到 排列 ...

  2. 数学(错排):BZOJ 4517: [Sdoi2016]排列计数

    4517: [Sdoi2016]排列计数 Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 693  Solved: 434[Submit][Status ...

  3. BZOJ 4517: [Sdoi2016]排列计数 [容斥原理]

    4517: [Sdoi2016]排列计数 题意:多组询问,n的全排列中恰好m个不是错排的有多少个 容斥原理强行推♂倒她 $恰好m个不是错排 $ \[ =\ \ge m个不是错排 - \ge m+1个不 ...

  4. [BZOJ4517][SDOI2016]排列计数(错位排列)

    4517: [Sdoi2016]排列计数 Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 1616  Solved: 985[Submit][Statu ...

  5. BZOJ 4517: [Sdoi2016]排列计数

    4517: [Sdoi2016]排列计数 Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 911  Solved: 566[Submit][Status ...

  6. bzoj-4517 4517: [Sdoi2016]排列计数(组合数学)

    题目链接: 4517: [Sdoi2016]排列计数 Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 846  Solved: 530[Submit][ ...

  7. 【数论·错位排列】bzoj4517 排列计数

    4517: [Sdoi2016]排列计数 Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 1428  Solved: 872[Submit][Statu ...

  8. BZOJ 2111: [ZJOI2010]Perm 排列计数 [Lucas定理]

    2111: [ZJOI2010]Perm 排列计数 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 1936  Solved: 477[Submit][ ...

  9. bzoj4517排列计数 错排+组合

    4517: [Sdoi2016]排列计数 Time Limit: 60 Sec  Memory Limit: 128 MBSubmit: 1491  Solved: 903[Submit][Statu ...

随机推荐

  1. 问题002:我们要使用的Java是哪个版本的?什么是JVM、JRE、JDK、IDE、API?

    三个版本:1.java SE 标准版 2.java EE企业版 3.Java ME 小型版本 JVM (java virtual machine) java虚拟机 JRE(java runtime e ...

  2. 4396: [Usaco2015 dec]High Card Wins

    Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 275  Solved: 175[Submit][Status][Discuss] Descriptio ...

  3. python实现批量修改文件名

    import os def dele(): # 设置一个计数器 n=0 st = input('请输入你要删除的字符:') for i in f: b = f[n] if st in b: oldna ...

  4. Http请求 GET和POST,405错误

    我就简单说吧,在用SringMVC时,我们通常会用到 @RequestMapping(value="/test",method=RequestMethod.GET) public ...

  5. Python知识点进阶——细节问题

    int()强制转换浮点数 在int()的强制转换浮点数时候,不管是正数还是负数,只取整数部分. 注意:这里不是向上或者向下取整,也不是四舍五入. 无限递归 递归是为了将问题简化为更小规模的同类型问题, ...

  6. pycharm配置Git托管

    利用Pycharm和github管理代码转载https://www.cnblogs.com/feixuelove1009/p/5955332.html git教程--廖雪峰git教程  转载https ...

  7. 常见的js算法面试题收集,es6实现

    1.js 统计一个字符串出现频率最高的字母/数字 let str = 'asdfghjklaqwertyuiopiaia'; const strChar = str => { let strin ...

  8. x01.xiangqi: 走动棋子

    采用 pygame 写的象棋程序,目前只完成绘制棋盘与走动棋子,还没考虑规则等问题. 1. 代码: """ x01.xiangqi (c) 2019 by x01&quo ...

  9. Linux命令之---nl

    命令简介 nl命令在linux系统中用来计算文件中行号.nl 可以将输出的文件内容自动的加上行号!其默认的结果与 cat -n 有点不太一样, nl 可以将行号做比较多的显示设计,包括位数与是否自动补 ...

  10. Curl之解决中文乱码

    利用iconv命令 curl http://www.baidu.com | iconv -f gb2312 -t utf-8 iconv命令可以将一种已知的字符集文件转换成另一种已知的字符集文件.它的 ...