题目就是求C(n,k)*H(n - k)%m

0<= k<= n <=10^9, 1 <= m <= 10^5, n != 0

其中H(n)是错排第n项。

对于C(n,k)%m可以参考我以前的文章

对于H(n)

直接套公式:

可以发现肯定在某一位会出现后面都是模完都是0

#include <cstdio>
#include <map>
using std::pair;
#define Pair pair<long long,long long>
const long long M = 100000 + 9;
long long fac[M],a[100],r[100];
struct triple{long long x,y,z;triple(const long long _x,const long long _y,const long long _z):x(_x),y(_y),z(_z){}};
triple exgcd(const long long a,const long long b)
{
if (!b) return triple(1,0,a);
triple last(exgcd(b,a%b));
return triple(last.y,last.x - a/b * last.y,last.z);
}
long long CRT(const long long (&a)[100],const long long (&r)[100],const long long cnt)
{
long long res = 0,MM = 1;
for (long long i = 1; i <= cnt; ++i) MM *= a[i];
for (long long i = 1; i <= cnt; ++i)
(res += exgcd(MM / a[i],a[i]).x % a[i] * r[i] % MM * (MM / a[i]) % MM) %= MM;
//printf("CRT %I64d\n",res + MM);
return (res + MM) % MM;
}
long long power(long long n,long long k,long long MOD)
{
n %= MOD;
long long res = 1;
for (; k; n = n * n % MOD,k /= 2)
if (k & 1) res = res * n % MOD;
return res;
}
long long H(const long long n,const long long MOD)
{
//H(n) = (3 * ... * n) - (4 * ... * n) + (5 * ... * n) + ... + (-1)^(n-1) * n + (-1)^n
if (n == 0) return 1 % MOD;
if (n == 1) return 0;
long long res = (n%2)?(-1):1;
for (long long i = n,t = res; i >= 3; --i) {
if (i % MOD == 0) break;
(t = - t * i) %= MOD;
(res += t) %= MOD;
}
//printf("TEST: %I64d\n",res + MOD);
return (res + MOD) % MOD;
}
Pair FnModP(long long n,const long long p,const long long MOD)
{
//Fn = n!
//fac[n] = n! % p
long long res = 1; long long c = 0;
while (n) {
(res *= power(fac[MOD],n / MOD,MOD)) %= MOD;
(res *= fac[n % MOD]) %= MOD;
n /= p;
c += n;
}
return std::make_pair(c,res);
}
void calc_fac(const long long p,const long long MOD)
{
fac[0] = 1;
for (long long i = 1; i <= MOD; ++i)
if (i % p) fac[i] = fac[i - 1] * i % MOD;
else fac[i] = fac[i - 1];
}
long long C(const long long n,const long long K,const long long p,const long long MOD)
{
//nCK % p^c
calc_fac(p,MOD);
Pair a(FnModP(n,p,MOD)),b(FnModP(K,p,MOD)),c(FnModP(n - K,p,MOD));
return 1ll * power(p,a.first - b.first - c.first,MOD) * a.second % MOD * ((exgcd(1ll * b.second * c.second % MOD,MOD).x % MOD + MOD) % MOD) % MOD;
}
long long work(long long n,long long K,long long MOD)
{
long long cnt = 0,c = 0;
const long long m = MOD;
for (long long i = 2; i * i <= MOD; ++i)
if (MOD % i == 0) {
a[++cnt] = 1;
for (c = 0; MOD % i == 0; MOD /= i) ++c,a[cnt] *= i;
r[cnt] = C(n,K,i,a[cnt]);
}
if (MOD > 1) r[++cnt] = C(n,K,MOD,MOD),a[cnt] = MOD;
//for (long long i = 1; i <= cnt; ++i) printf("%I64d %I64d\n",a[i],r[i]);
return 1ll * CRT(a,r,cnt) * H(n - K,m) % m;
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("SEQN.in","r",stdin);
freopen("SEQN.out","w",stdout);
#endif
long long T,n,K,MOD;
scanf("%I64d",&T);
for (long long i = 1; i <= T; ++i) {
scanf("%I64d%I64d%I64d",&n,&K,&MOD);
printf("Case %I64d: %I64d\n",i,(work(n,K,MOD)%MOD + MOD)%MOD);
}
}

  

[SPOJ SEQN] [hdu3439]Sequence的更多相关文章

  1. 【spoj SEQN】【hdu 3439】Sequence

    题意: 给出n.m.k 求C(n,k)*H(n-k)%m的值 H(n-k)为错排公式 题解: 先算H(n-k) 计算H(n)有个通式: H(n)=(-1)^n+((-1)^(n-1))n+((-1)^ ...

  2. spoj 2319 BIGSEQ - Sequence

    You are given the sequence of all K-digit binary numbers: 0, 1,..., 2K-1. You need to fully partitio ...

  3. HDU3439 Sequence

    今天下午学习了二项式反演,做了一道错排的题,开始了苦逼的经历. 显然答案是C(︀n,k)︀*H(n − k).其中H(i)为长度为i的错排序列 然后经过课件上一番二项式反演的推导 我就写了个扩展卢卡斯 ...

  4. Bluetooth Baseband介绍

    目录 1. 概述 1.1 Clock(时钟) 1.2 寻址方式 2. 物理信道(Physical Channels) 3. 物理链路(Physical Links) 4. 逻辑传输层(Logical ...

  5. 蓝牙baseband概述

    从蓝牙specispecification中看,基带协议主要分为8个部分来介绍的,分别是概述.物理信道.物理连接.逻辑传输.逻辑连接.封包.比特流的处理.组网行为.这里面会涉及到很多的概念,主要是在概 ...

  6. 【专题】数位DP

    [资料] ★记忆化搜索:数位dp总结 之 从入门到模板 by wust_wenhao 论文:浅谈数位类统计问题 数位计数问题解法研究 [记忆化搜索] 数位:数字从低位到高位依次为0~len-1. 高位 ...

  7. 【SPOJ 2319】 BIGSEQ - Sequence (数位DP+高精度)

    BIGSEQ - Sequence You are given the sequence of all K-digit binary numbers: 0, 1,..., 2K-1. You need ...

  8. 【SPOJ】2319 BIGSEQ - Sequence

    [算法]数位DP [题解]动态规划 题目要求的是大整数……没办法只写了小数字的,感觉应该没错. 大题框架是最大值最小化的二分问题. 对于每一块要求count(b)-count(a-1)≥s 已知a如何 ...

  9. 【SPOJ】1182 Sorted bit sequence

    [算法]数位DP [题解]动态规划 写了预处理函数却忘了调用是一种怎样的体验? #include<cstdio> #include<cstring> #include<a ...

随机推荐

  1. TED_Topic1:Why we need to rethink capitalism

    Topic 1:Why we need to rethink capitalism By Paul Tudor Jones II # Background about our speaker      ...

  2. 基本控件文档-UITextField属性---iOS-Apple苹果官方文档翻译

    本系列所有开发文档翻译链接地址:iOS7开发-Apple苹果iPhone开发Xcode官方文档翻译PDF下载地址 //转载请注明出处--本文永久链接:http://www.cnblogs.com/Ch ...

  3. 面试整理(3)js事件委托

    事件委托主要用于一个父容器下面有很多功能相仿的子容器,这时候就需要将子容器的事件监听交给父容器来做.父容器之所以能够帮子容器监听其原理是事件冒泡,对于子容器的点击在冒泡时会被父容器捕获到,然后用e.t ...

  4. win10环境变量

    jdk8 JAVA_HOME D:\devsoft\jdk\jdk1.8 CLASSPATH .;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar pa ...

  5. Django【进阶】modelform

    modelform:models+form   建议尽量用Djangoform,更灵活,但也有人用modelform,写起来很简单 缺点,在models里面,表模型必须有__str__()方法 可添加 ...

  6. 78.PL和PS通过BRAM交互共享数据

    本篇文章目的是使用Block Memory进行PS和PL的数据交互或者数据共享,通过zynq PS端的Master GP0端口向BRAM写数据,然后再通过PS端的Mater GP1把数据读出来,将结果 ...

  7. html---规范、细节积累-01

    语义错误 块级元素可以包含内联元素和某些块级元素,内联元素不能包含块级元素,只能包含内联元素 页面可能正常解析,但不符合语义.浏览器自带容错机制,对于不规范的写法也能够正确解析,各浏览器的容错机制不同 ...

  8. Java 序列化工具类

    import org.slf4j.Logger; import org.slf4j.LoggerFactory; import sun.misc.BASE64Decoder; import sun.m ...

  9. PHP缓存加速插件 XCache 、 ZendOpcache 安装

    PHP缓存原理 当客户端请求一个PHP程序时,服务器的PHP引擎会解析该PHP程序,并将其编译为特定的操作码(OperateCode,简称opcode)文件,该文件是PHP代码的一种二进制表示方式.默 ...

  10. charles抓包误点deny处理办法及日常抓包

    误点deny方法在最底下~~ (博文为转载) 我们在开发网站项目的时候,我们可以通过浏览器的debug模式来看request以及response的数据,那么如果我们开发移动端项目没有网页呢?如何抓取数 ...