模非素数下的排列组合,简直凶残

调着调着就过了= =

都不知道怎么过的= =

直接上链接http://hi.baidu.com/aekdycoin/blog/item/147620832b567eb40df4d258.html

CODE:

#include<cstdio>

#include<iostream>

#include<cstring>

#include<algorithm>

#include<cmath>

using namespace std;

typedef long long ll;

ll a[3][50],pri[50],M[50],t[50];

ll ex_gcd(ll a,ll b,ll &x,ll &y) {

if (b==0)  {x=1,y=0 ;return a;}

ex_gcd(b,a%b,x,y);

x=x-a/b*y;

swap(x,y);

return 0;

}

ll p;

int l,sum[50];

int fen(int p){

for (int i=2;i<=sqrt(p);i++) {

if (p%i==0) {

pri[++l]=i;

while (p%i==0) {

sum[l]++;

p/=i;

}

}

}

if (p>1) {pri[++l]=p;sum[l]=1;}

return 0;

}

ll power(ll x,ll y,ll mod){

if (y==0) return 1;

ll ans=power(x,y>>1,mod);

ans=ans*ans%mod;

if (y&1) ans=ans*x%mod;

return ans;

}

ll f[100101],cnt;

ll calcfac(ll n,ll p,ll pi){

if (n<pi) return f[n];

// printf("%lld %lld",pi,pri[1]);

ll seg=n/p,rem=n%p;

ll ret=power(f[p-1],seg,p);

ret=ret*f[rem]%p;

cnt+=n/pi;

ret=ret*calcfac(n/pi,p,pi)%p;

return ret;

}

ll china(ll *a,ll *b) {

ll tem,ans=0;

for (int i=2;i<=l;i++) {

ll x,y;

ex_gcd(b[i-1],b[i],x,y);

b[i]=b[i]*b[i-1];

a[i]=((x*(a[i]-a[i-1])*b[i-1]+a[i-1])%b[i]+b[i])%b[i];

}

return a[l];

}

ll b[51];

ll c(int n,int m){

for (int i=1;i<=l;i++) {

ll p=1;

for (int j=1;j<=sum[i];j++) p*=pri[i];

f[0]=1;

for (int j=1;j<p;j++) {

f[j]=f[j-1];

if (j%pri[i]==0) continue;

f[j]=(f[j]*j)%p;

}

cnt=0;ll ans,tem;

a[1][i]=calcfac(n,p,pri[i]);

tem=cnt;cnt=0;

a[2][i]=calcfac(m,p,pri[i]);

printf("%lld\n",pri[1]);

a[3][i]=calcfac(n-m,p,pri[i]);

cnt=tem-cnt;

a[2][i]=a[3][i]*a[2][i]%p;

ex_gcd(a[2][i],p,ans,tem);

ans=(ans%p+p)%p;

a[1][i]=a[1][i]*ans%p*power(pri[i],cnt,p)%p;

b[i]=p;

}

return (china(a[1],b));

}

ll te[8];

int main(){

ll n,m;

ll tmp=0;

scanf("%lld %lld %lld",&p,&n,&m);

for (int i=1;i<=m;i++) {

scanf("%lld",&te[i]);

tmp+=te[i];

}

if (tmp>n) {printf("Impossible");return 0;}

fen(p);

for (int i=1;i<=l;i++) printf("%lld %lld\n",pri[i],sum[i]);

ll ans=1;

for (int i=1;i<=m;i++) {

ans=ans*c(n,te[i])%p;

n-=te[i];

// if (ans==0) {printf("%d\n",0);return 0;}

printf("\n\n");

}

printf("%lld",ans);

return 0;

}

BZOJ 2142: 礼物的更多相关文章

  1. BZOJ 2142: 礼物 [Lucas定理]

    2142: 礼物 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 1294  Solved: 534[Submit][Status][Discuss] ...

  2. BZOJ 2142 礼物 组合数学 CRT 中国剩余定理

    2142: 礼物 Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 1450  Solved: 593[Submit][Status][Discuss] ...

  3. 【刷题】BZOJ 2142 礼物

    Description 一年一度的圣诞节快要来到了.每年的圣诞节小E都会收到许多礼物,当然他也会送出许多礼物.不同的人物在小E 心目中的重要性不同,在小E心中分量越重的人,收到的礼物会越多.小E从商店 ...

  4. bzoj 2142 礼物——扩展lucas模板

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2142 没给P的范围,但说 pi ^ ci<=1e5,一看就是扩展lucas. 学习材料 ...

  5. bzoj 2142: 礼物【中国剩余定理+组合数学】

    参考:http://blog.csdn.net/wzq_qwq/article/details/46709471 首先推组合数,设sum为每个人礼物数的和,那么答案为 \[ ( C_{n}^{sum} ...

  6. BZOJ.2142.礼物(扩展Lucas)

    题目链接 答案就是C(n,m1) * C(n-m1,m2) * C(n-m1-m2,m3)...(mod p) 使用扩展Lucas求解. 一个很简单的优化就是把pi,pi^ki次方存下来,因为每次分解 ...

  7. BZOJ - 2142 礼物 (扩展Lucas定理)

    扩展Lucas定理模板题(貌似这玩意也只能出模板题了吧~~本菜鸡见识鄙薄,有待指正) 原理: https://blog.csdn.net/hqddm1253679098/article/details ...

  8. BZOJ 2142 礼物 数论

    这道题是求组合数终极版. C(n,m) mod P n>=1e9 m>=1e9 P>=1e9且为合数且piqi<=1e5 拓展lucas定理. 实际上就是一点数论小知识的应用. ...

  9. bzoj 3055礼物运送 floyed + 状压DP

    bzoj 3055: 礼物运送 floyed first 设f[i][S]表示取到了S集合中的所有点(不一定是经过的所有点),最后停在了i的最优值. 初始就f[i][{i}] = dis[1][i] ...

随机推荐

  1. Vector类

    /* * Vector的特有功能 * * Vector出现较早,比集合更早出现 * * 1:添加功能 * public void addElement(Object obj);//用add()替代 * ...

  2. yield return 和yield break

    这个还是有点意思,两个都是有返回的意思,但是区别在哪里呢? 1.return 会销毁函数的局部变量,下次调用的时候又会产生新的值 2.yield 当退出函数的时候,变量人然存在,函数下次调用的时候变量 ...

  3. UVa 11503 - Virtual Friends

    题目大意:给出若干对朋友关系,每给出一对朋友关系,就输出二者所在关系网中的人数. 首先是对每个人编号,使用map简化编号过程,然后就是使用并查集更新集合.要注意的是当给出A和B的朋友关系时,无论A和B ...

  4. ubuntu 安装chrome浏览器

    对于一个一直用chrome的人来说,真的很不习惯用firefox,虽然firebug很好用.. 好吧,心情不佳,直接上命令: 下载命令(有墙,下不下来,多试几次): wget https://dl.g ...

  5. Java 之 Servlet介绍(Java之负基础实战)

    1.介绍 Servlet是用Java编写的服务器端程序.其主要功能在于交互式地浏览和修改数据,生成动态Web内容.狭义的Servlet是指Java语言实现的一个接口,广义的Servlet是指任何实现了 ...

  6. 9 Python+Selenium鼠标事件

    [环境信息] python3.6+Selenium3.0.2+Firefox50.0+win7 [ActionChains类鼠标事件的常用方法] 1.右击:context_click() 2.双击:d ...

  7. WEB 开发者应该具备的 6 大技能?

    1. 界面和用户体验 注意,浏览器的实现标准是不一致的,请确保你的网站能够兼容所有主流的浏览器.最少需要测试的有 Gecko 引擎 (Firefox),WebKit引擎(Safari以及一些手机浏览器 ...

  8. Angular - - ngReadonly、ngSelected、ngDisabled

    ngReadonly 该指令将input,textarea等文本输入设置为只读. HTML规范不允许浏览器保存类似readonly的布尔值属性.如果我们将一个Angular的插入值表达式转换为这样的属 ...

  9. Thinkphp代码生成工具 ThinkphpHelper

    支持MySQL 和 sqlite数据库,快速构建项目原型,直接生成前后台CRUD代码片段,还可根据需要自行定制代码模板,减少重复劳动. 写这个东西的原因是因为我最近沮丧的发现很多时候我都在做重复的事情 ...

  10. Java Swing JScrollPane 设置滚动量

    JScrollPane.getVerticalScrollBar().setUnitIncrement(20); 参考:http://bbs.csdn.net/topics/320249228