[微信机器人_04]自然语言处理简单实现

对于两个正整数[微信机器人_04]自然语言处理简单实现,由欧拉定理可知,存在正整数[微信机器人_04]自然语言处理简单实现, 比如说欧拉函数[微信机器人_04]自然语言处理简单实现,即小于等于 m 的正整数中与 m 互质的正整数的个数,使得[微信机器人_04]自然语言处理简单实现

由此,在[微信机器人_04]自然语言处理简单实现时,定义[微信机器人_04]自然语言处理简单实现对模[微信机器人_04]自然语言处理简单实现的指数[微信机器人_04]自然语言处理简单实现为使[微信机器人_04]自然语言处理简单实现成立的最小的正整数[微信机器人_04]自然语言处理简单实现。由前知[微信机器人_04]自然语言处理简单实现 一定小于等于 [微信机器人_04]自然语言处理简单实现,若[微信机器人_04]自然语言处理简单实现,则称[微信机器人_04]自然语言处理简单实现是模[微信机器人_04]自然语言处理简单实现的原根

摘自*


这个题目就是要求一个质数n的最大的原根

现在的问题就是怎么求原根,如果直接暴力是 O(nlogn * 因子数),显然是不行的。。

方法:

如果q不是n的原根,那么必然存在一个t < n-1且 q^t = 1(mod n),这里我就假设q^t = 1(mod n), t肯定是整除n-1的(想想就明白)

根据裴蜀定理可知ax+by=gcd(a,b)必然有解

所以必然存在tx + (n-1)y = gcd(t, n-1),所以q^(tx) = 1 = q^( -(n-1)y + gcd(t, n-1)) = q^( gcd(t, n-1) ) ,即q^( gcd(t, n-1) ) = 1

因为t < n-1 且t 整除n-1,所以 t 至少整除 (n-1)/pi (1 <= i <=  tot)中的一个,pi为n-1的素因子

所以要判断q是不是n的原根,只需要判断 q^( (n-1)/pi ) % n 其中如果有一个等于1的话,那q就不是原根!


代码:


[微信机器人_04]自然语言处理简单实现

上一篇:很简单却很酷的粒子破碎效果--IT蓝豹


下一篇:政务微信门户建设思考