博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 5446(中国剩余+lucas+按位乘)
阅读量:5825 次
发布时间:2019-06-18

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

题意:c( n, m)%M    M = P1 * P2 * ......* Pk

Lucas定理是用来求 c(n,m) mod p,p为的值。得出一个存余数数组,在结合中国剩余定理求值

其中有个地方乘积可能超范围,所以按位乘(数论方面薄弱啊,学习学习)。

#include 
#include
#include
#include
#include
using namespace std;typedef long long ll;ll p[15],an[15];ll fac[100005],inv[100005];ll pow_mod(ll a, int n, int mod){ ll ret = 1; while (n) { if (n&1) ret = ret * a % mod; a = a * a % mod; n >>= 1; } return ret;}void ini(int x){ fac[0] = 1; for(int i = 1; i < x; i++) fac[i] = fac[i-1]*i%x; inv[x - 1] = pow_mod(fac[x-1],x-2,x); for(int i = x - 2; i >= 0; i--) inv[i] = inv[i+1] * (i+1) % x;}ll c(ll a,ll b,ll p){ if(a < b || a < 0 || b < 0) return 0; return fac[a]*inv[b]%p*inv[a-b]%p;}ll lucas(ll a,ll b, int p){ if( b == 0) return 1; return lucas(a/p,b/p,p)*c(a%p,b%p,p)%p;}ll ex_gcd(ll a, ll b, ll& x, ll& y){ if (b == 0) { x = 1; y = 0; return a; } ll d = ex_gcd(b, a % b, y, x); y -= x * (a / b); return d;}ll mul(ll a, ll b, ll mod){ a = (a % mod + mod) % mod; b = (b % mod + mod) % mod; ll ret = 0; while(b) { if(b&1) { ret += a; if(ret >= mod) ret -= mod; } b >>= 1; a <<= 1; if(a >= mod) a -= mod; } return ret;}ll china(ll n,ll* a,ll* b){ ll M = 1,d,y,x= 0; for(int i = 0; i < n; i++) { M *= b[i]; } for(int i = 0; i < n; i++) { ll w = M/b[i]; ex_gcd(b[i],w,d,y); x = (x + mul(mul(y, w, M), a[i], M));//可能超范围 } return (x+M) % M;}int main(){ int T,k; ll n,m; scanf("%d",&T); while(T--) { scanf("%I64d%I64d",&n,&m); scanf("%d",&k); for(int i = 0; i < k; i++) { scanf("%I64d",&p[i]); ini(p[i]); an[i] = lucas(n,m,p[i]); } printf("%I64d\n",china(k,an,p)); } return 0;}

  

转载于:https://www.cnblogs.com/Przz/p/5409757.html

你可能感兴趣的文章
Windows 8下如何删除无线配置文件
查看>>
解决Windows 7中文件关联和打开方式
查看>>
oracle系列(五)高级DBA必知的Oracle的备份与恢复(全录收集)
查看>>
hp 服务器通过串口重定向功能的使用
查看>>
国外10大IT网站和博客网站
查看>>
android第十一期 - SmoothSwitchLibrary仿IOS切换Activity动画效果
查看>>
zabbix 批量web url监控
查看>>
MongoDB CookBook读书笔记之导入导出
查看>>
shell如何快速锁定所有账号
查看>>
HTML 5实现的手机摇一摇
查看>>
Linux 文件IO理解
查看>>
Ninject 2.x细说---2.绑定和作用域
查看>>
30个非常时尚的网页联系表单设计优秀示例
查看>>
使用membership(System.Web.Security)来进行角色与权限管理
查看>>
opticom 语音质量验证白皮书
查看>>
3D实时渲染中的BSP树和多边形剔除
查看>>
Frank Klemm's Dither and Noise Shaping Page: Dither and Noise Shaping In MPC/MP+
查看>>
网络抓包的部署和工具Wireshark【图书节选】
查看>>
Redis在Windows+linux平台下的安装配置
查看>>
Maven入门实战笔记-11节[6]
查看>>