ACM_算法_Lucas定理
来源:互联网 发布:foreach遍历数组 编辑:程序博客网 时间:2024/06/06 20:08
Lucas定理是用于求解C(n,m)%p的问题
这里小编用一张图:
这张图就很完整的说明了Lucas定理的内容,比较简单,也比较好理解,小编也就不多说了。
#include <cstdio>#include <cstring>#include <iostream>#include <algorithm>using namespace std;typedef long long LL;LL Power_mod(LL a, LL b, LL p){LL res = 1;while(b!=0){if(b&1) res = (res*a)%p;a = (a*a)%p;b >>= 1;}return res;}LL Comb(LL a,LL b, LL p){if(a < b) return 0;if(a == b) return 1;if(b > a-b) b = a-b;LL ans = 1, ca = 1, cb = 1;for(LL i=0; i<b; ++i){ca = (ca*(a-i))%p;cb = (cb*(b-i))%p;}ans = (ca*Power_mod(cb, p-2, p))%p;return ans;}LL Lucas(int n, int m, int p){LL ans = 1;while(n && m && ans){ans = (ans * Comb(n%p, m%p, p))%p;n /= p;m /= p;}return ans;}int main(){int n,m,p;while(scanf("%d%d%d",&n,&m,&p) !=EOF){printf("%lld\n",Lucas(n,m,p));}return 0;}
0 0
- ACM_算法_Lucas定理
- 模板_Lucas定理
- ACM_归并排序算法
- ACM_快速排序算法
- ACM_扩展欧几里德算法
- ACM_模板_Tarjan算法
- ACM_模板_KMP算法
- ACM_模板_Manacher算法
- ACM_扩展欧几里得算法
- acm_随机算法
- ACM_置换群 burnside引理 Polya定理
- ACM_模板_中国剩余定理(互质与非互质)
- 杭电ACM_算法题-动态规划
- ACM_算法竞赛入门_源程序
- 【ACM_数论初步】欧几里德算法及其应用
- ACM_程序设计竞赛:贪心算法:硬币问题
- ACM_程序设计竞赛:贪心算法:区间问题
- ACM_模板_Gale_Shapley算法(稳定婚姻)
- Spring AspectJ AOP 完整示例
- poj1470Closest Common Ancestors(LCA模版)
- js推拉门
- iOS关于系统原生通知的实现
- MFC消息映射
- ACM_算法_Lucas定理
- JDBC介绍(详细版)
- 计算textview 文字宽度
- Spring整合Mybatis简要概括
- [LeetCode] Longest Consecutive Sequence
- solution Of 1095. Cars on Campus (30)
- 钱:越舍得花越有,越不舍得越穷!
- subline text 插件 整合
- [Leetcode]6. ZigZag Conversion