【关于 A^x = A^(x % Phi(C) + Phi(C)) (mod C) 的若干证明】【指数循环节】

原文地址:http://hi.baidu.com/aekdycoin/item/e493adc9a7c0870bad092fd9
曾经看过如下一个公式:

以上的公式如果第一次见到,难免有不少疑惑:
为什么可以这么写?限制条件为什么是x >= Phi(C),这个公式为什么正确?
今天突发奇想,在纸上YY以后得到了以下证明(个人证明,如果有问题欢迎提出)
定理 1:
对于一个数对(A,C) 必然存在一个最小的正整数 L,满足

其中SPOS 是一个大于等于0的整数(下面具体介绍)
我们称L 为(A,C) 的最小循环节长度
证明:
根据鸽巢原理,得到在x >= C 后必然出现循环,从而定理得证.
定理 2:
对于数对 (A,C) 下面的公式必然成立

其中 k >= 0
既L 的任意倍数均为一个新的循环节长度.
证明:
根据定理1,不难得证.
定理 3:
对于数对 (A,C) 必然存在 一个最大的SPOS >=0 ,满足
(1)    若x属于区间 [0,SPOS -1] 内,得到的一个剩余系的长度为SPOS;
(2)    该剩余系和x属于[SPOS,+oo]的剩余系的交集为空!
证明:
对于一个SPOS,由于[0,SPOS-1]内不存在循环,所以x属于[0,SPOS-1]内得到的值是唯一的.
而第二点的证明也不难,因为如果不为空,那么必然可以缩小SPOS的值.
定理 4:
对于数对 (A,C) 若 (A,C) == 1,那么 L | Phi(C)
证明:
显然可以由欧拉公式,得到
A^Phi(C) = 1 (mod C)
而A^0 = 1 (mod C),于是出现了循环
由定理2,该定理得证.
定理5:
对于数对 (A,C) 若 A|C
那么有
SPOS >= CNT
其中CNT为满足  A^CNT | C的最大的正整数
下面分2个情况
(1) A^CNT == C
果断显然成立
(2) A^CNT  * B = C
于是我们假设对于[0,CNT] 内存在某个数i,有
A^i = A^x (mod C)
而由于x > CNT (因为[0,CNT]内不存在循环)
所以
A^CNT * A^(x - CNT) = A^i (mod A^CNT * B)
显然如果 i < CNT
那么是不可能有解的
因为(A^CNT, A^CNT * B) | A^i 显然不成立
于是Spos >= CNT 得证
定理 6:
对于一个数对 (A,C) 若存在

那么有 L | M
根据定理1,2 不难得到.
好了,上面写了那么多,是为了介绍 循环节的基本定理
下面开始正题,开始公式的证明
我们对于A 进行分解,得到素因子集合

下面我们把素因子分为2类
(1)    (Pi,C) == 1
(2)    (Pi,C) != 1
对于第一类情况,我们容易由定理4知道对于每一个 Pi,得到了Li (  数对 (Pi,C) 的最小循环节长) 必然是 Phi(C) 的因子
对于第二类情况,由定理5,”消去 因子”,转化为第一类的情况.得到了 这类的素因子Pi 的Li 依然为Phi(C) 的因子

@2011-01-11 对于第二类情况的更新

由循环定义得到

(Pi^ci)^x = (Pi^ci)^(x + Li) (mod C) (x >= spos)

那么我们假设C = Pi^CNT * B, 其中 (B, Pi) = 1

那么

(Pi^ci)^x = (Pi^ci)^(x + Li) (mod Pi^CNT * B)

同时消去Pi因子,最终可以得到:

[Pi^a] * [Pi^ci]^b = [Pi^a] * [Pi^ci]^b * [Pi^ (ci  * Li)] (mod B)

(Pi^a, B) = 1,逆元存在,2边同时乘上 Pi^a的逆元

[Pi^ci]^b = [Pi^ci]^b * [Pi^ (ci  * Li)] (mod B)

===>

[Pi^ci] ^b = [Pi^ci] ^ (b + Li) (mod B)

Li 为Phi(B)的因子,B为C的因子,既

Li | Phi(B), B| C

下面我们构造所有素因子的循环,既求他们的LCM,那由于定理6不难知道,(A,C) 的最小循环节长 L | LCM(L1,L2…LK)
而Li |Phi(C)
所以 L | Phi(C)
之后由定理1,2 公式得证.
推荐题目:
http://acm.fzu.edu.cn/problem.php?pid=1759
Problem 1759 Super A^B mod C  直接运用公式
http://acm.hdu.edu.cn/showproblem.php?pid=3221
2009年shanghai B,得到DP以后利用公式
http://acm.hdu.edu.cn/showproblem.php?pid=2837
Calculation 递归,注意细节
PS.  标程在某个细节处理错误,可是数据是对的.

【转】【关于 A^x = A^(x % Phi(C) + Phi(C)) (mod C) 的若干证明】【指数循环节】的更多相关文章

  1. CH BR13数学(啥?-a^b≡a^b mod phi(p)+phi(p)(mod p)(b>=phi(p))公式)

    啥? Beta Round #13 (数学专场) 背景 有人写了一个RSA加密给我玩. 描述 我赌5毛前面两题的内容也就开头几句话平时会用到. 还是做点具体的东西吧. 求c^d Mod N 输入格式 ...

  2. P4139 上帝与集合的正确用法[欧拉定理]

    题目描述 求 \[ 2^{2^{2\cdots}} ~mod ~p \] 简单题,指数循环节. 由于当\(b>=\psi(p)\)时,有 \[ a^b=a^{b ~mod~\psi(p)+\ps ...

  3. UVA 10692 Huge Mods(指数循环节)

    指数循环节,由于a ^x = a ^(x % m + phi(m)) (mod m)仅在x >= phi(m)时成立,故应注意要判断 //by:Gavin http://www.cnblogs. ...

  4. hdu 2837 Calculation 指数循环节套路题

    Calculation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  5. FZU 1759 Super A^B mod C 指数循环节

    Problem 1759 Super A^B mod C Time Limit: 1000 mSec    Memory Limit : 32768 KB  Problem Description G ...

  6. hdu 5895 Mathematician QSC 指数循环节+矩阵快速幂

    Mathematician QSC Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Othe ...

  7. 牛客OI测试赛 F 子序列 组合数学 欧拉降幂公式模板

    链接:https://www.nowcoder.com/acm/contest/181/F来源:牛客网 题目描述 给出一个长度为n的序列,你需要计算出所有长度为k的子序列中,除最大最小数之外所有数的乘 ...

  8. 【BZOJ 2818】Gcd - 筛法求素数&phi()

    题目描述 给定整数,求且为素数的数对有多少对. 分析 首先筛出所有的素数. 我们考虑枚举素数p,统计满足的个数,等价于统计的个数,即统计以内满足互质的有序数对个数. 不难发现,也就是说,我们只要预处理 ...

  9. 既约分数-phi

    Description 小明正在学习分数这一章,他想知道对于一个真分数b/a而言,当分母a在[2,N]之间时,存在多少个既约分数,例如当N=4时,有以下几个1/2,1/3,1/4,2/3,3/4这五个 ...

随机推荐

  1. 2019牛客暑期多校训练营(第七场)A.String【最小表示法】

    传送门:https://ac.nowcoder.com/acm/contest/887/A 题意:大意就是给你一个只含有0和1的字符串,找出一种分割方法,使得每个分割出的字符串都是在该字符串自循环节中 ...

  2. 干货|Kubernetes集群部署
Nginx-ingress Controller

    Kubernetes提供了两种内建的云端负载均衡机制用于发布公共应用,一种是工作于传输层的Service资源,它实现的是TCP负载均衡器:另一种是Ingress资源,它实现的是HTTP(S)负载均衡器 ...

  3. matlab画图中的坐标轴设置

    ax = gca; ax是个结构体,查看ax变量,可以看到所有可设置的属性.几个常见属性如下: 设置坐标轴字体大小,粗细,字体名 2014b之后版本: ax = gca; ax.FontSize = ...

  4. [原]调试实战——使用windbg调试TerminateThread导致的死锁

    原调试debugwindbg死锁deadlock 前言 项目里的一个升级程序偶尔会死锁,查看dump后发现是死在了ShellExecuteExW里.经验少,不知道为什么,于是在高端调试论坛里发帖求助, ...

  5. ZJNU 1269 - 灯塔——高级

    根据题目输入可以得到一个有向图 信号可以根据有向图的传递性传递,因此可以说是找到这个有向图的所有父亲即可 但又要考虑可能会出现环这类情况 所以跑一遍强连通分量模板,再根据分块后的图找到入度为0的块,把 ...

  6. p2p gossip 结构化 非结构化

    p2p P2P中文名字叫对等网络,网络中节点地位一致.    QQ其实不算P2P,因为QQ利用了中央服务器.   Hbase这样的分布式系统,因为有Hmaster节点,也不算是P2P网络:   cas ...

  7. \_\_del\_\_

    __del__ 一.__del__ __del__也称之为析构方法 __del__会在对象被删除之前自动触发 print('主')class People: def __init__(self, na ...

  8. anaconda学习笔记

    anaconda介绍 Anaconda指的是一个开源的Python发行版本,其包含了conda.Python等180多个科学包及其依赖项. Conda是一个开源的包.环境管理器,可以用于在同一个机器上 ...

  9. 14 微服务电商【黑马乐优商城】:day06-使用nginx反向代理并掌握cors解决跨域

    本项目的笔记和资料的Download,请点击这一句话自行获取. day01-springboot(理论篇) :day01-springboot(实践篇) day02-springcloud(理论篇一) ...

  10. mysql查看变量

    在MySQL客户端执行如下命令查看MySQL的数据存放位置: show global variables like "%datadir%"; 查看端口号 show global v ...