\(n\) 次剩余

你需要解方程 \(x^n\equiv k\pmod m\),其中 \(x\in [0,m-1]\)。

保证解数不超过 \(C=10^6\)

\(1\le n,m,k\le 10^9\)

\(k<m\)

Sol

(1)\(m\) 是奇质数

此时 \(m\) 有原根,两边取对数得 \(ny\equiv b \pmod {m-1}\),使用 \(\text{exgcd}\) 可以求出 \(y\) 在 \([0,m-1]\) 的解。

(2)\(m=p^e\) , \(p\) 是奇质数。

令 \(k\%m \rightarrow k\) 然后分三种情况讨论如下

1、\(k=0\)

显然当且仅当 \(p^{\lceil \frac e n \rceil}\) 时等式能成立,故直接枚举 \(p^{\lceil \frac e n \rceil}\) 的倍数即可。

2、\((k,p^e)=1\)

取对数得 \(ny\equiv b \pmod{\varphi(p^e)}\)

这样的方程有解必须有 \(\gcd(n,\varphi(p^e)) \mid b\)

然后依然可以使用 \(\text{exgcd}\) 求解,然后再用指标算出 \(x=g^y\)。

3、\((k,p^e)> 1\)

我们设 \(k=c\times p^j ((c,p)=1)\)

这样的方程有解必须有 \(n \mid j\)

然后我们除去 \(p^j\) :\(\displaystyle \left(\frac{x}{p^{\frac{j}{n}}}\right)^n\equiv c\pmod{p^{e-j}}\)

换元 \(u=\frac{x}{p^{\frac{j}{n}}}\),\(u^n\equiv c \pmod{p^{e-j}}\),此时和第 2 种情况一模一样,我们套用之前方法求解。

此处有重大坑点,先跳过。

(3)\(m=2^d\)

因为要输出所有解,解的个数不多,可以倍增,那么它在模 \(2^{k-1}\) 情况下的所有解 \(x\),如果还要在 \(2^k\) 成立,必定是 \(x\) 或 \(x+2^{k-1}\)。
我们对于每一个 \(x\) 检查一下就好了,然后可以 bfs 出所有解。

最终求解

综上,我们对于一个任意正整数 \(m\),只要对其的唯一分解形式 \(m=p_1^{q_1}p_2^{q_2}\dots\) 的每个质数进行求解即可,

最后跑一遍 DFS 枚举模每个 \(p^q\) 意义下的值,用 CRT(中国剩余定理)合并即可。

许多坑点

1、对 \(p^k\) 求原根,check 的时候要用 \(\varphi(p^k)\) 而不是直接 \(p^k-1\)

2、在原式中 \(x\) 的取值范围是 \([0,p^e)\),那么 \(y=\frac{x}{p^{\frac{j}{n}}}\) 的取值范围就是 \([0,p^{e-\frac{j}{n}})\);

可是在后一个式子中 \(y\) 的取值范围变成了 \([0,p^{e−j})\)!!

因此我们最后的解的个数需要扩大 \(p^{j−j/n}\) 倍,我们枚举 \([0,p^{e−j})\) 中的解向后不断扩展即可。

3、你需要一个正确的 BSGS 板子

4、正确的写法对于任何一个解的 vector 都不需要 unique 的,如果求出大量重复的解可能会被卡掉。

任意模数 n 次剩余的更多相关文章

  1. 【51nod】1123 X^A Mod B (任意模数的K次剩余)

    题解 K次剩余终极版!orz 写一下,WA一年,bug不花一分钱 在很久以前,我还认为,数论是一个重在思维,代码很短的东西 后来...我学了BSGS,学了EXBSGS,学了模质数的K次剩余--代码一个 ...

  2. 【知识总结】多项式全家桶(三)(任意模数NTT)

    经过两个月的咕咕,"多项式全家桶" 系列终于迎来了第三期--(雾) 上一篇:[知识总结]多项式全家桶(二)(ln和exp) 先膜拜(伏地膜)大恐龙的博客:任意模数 NTT (在页面 ...

  3. 再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT)

    再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Bluestein算法+分治FFT+FFT的优化+任意模数NTT) 目录 再探快速傅里叶变换(FFT)学习笔记(其三)(循环卷积的Blueste ...

  4. 51NOD 1258 序列求和 V4 [任意模数fft 多项式求逆元 伯努利数]

    1258 序列求和 V4 题意:求\(S_m(n) = \sum_{i=1}^n i^m \mod 10^9+7\),多组数据,\(T \le 500, n \le 10^{18}, k \le 50 ...

  5. 【集训队作业2018】取名字太难了 任意模数FFT

    题目大意 求多项式 \(\prod_{i=1}^n(x+i)\) 的系数在模 \(p\) 意义下的分布,对 \(998244353\) 取模. \(p\) 为质数. \(n\leq {10}^{18} ...

  6. 任意模数NTT

    任意模数\(NTT\) 众所周知,为了满足单位根的性质,\(NTT\)需要质数模数,而且需要能写成\(a2^{k} + r\)且\(2^k \ge n\) 比较常用的有\(998244353,1004 ...

  7. BZOJ1042 HAOI2008硬币购物(任意模数NTT+多项式求逆+生成函数/容斥原理+动态规划)

    第一眼生成函数.四个等比数列形式的多项式相乘,可以化成四个分式.其中分母部分是固定的,可以多项式求逆预处理出来.而分子部分由于项数很少,询问时2^4算一下贡献就好了.这个思路比较直观.只是常数巨大,以 ...

  8. [洛谷P4245]【模板】任意模数NTT

    题目大意:给你两个多项式$f(x)$和$g(x)$以及一个模数$p(p\leqslant10^9)$,求$f*g\pmod p$ 题解:任意模数$NTT$,最大的数为$p^2\times\max\{n ...

  9. 拆系数FFT(任意模数FFT)

    拆系数FFT 对于任意模数 \(mod\) 设\(m=\sqrt {mod}\) 把多项式\(A(x)\)和\(B(x)\)的系数都拆成\(a\times m+b\)的形式,时\(a, b\)都小于\ ...

随机推荐

  1. render(七)

    Vue 的 _render 方法是实例的一个私有方法,它用来把实例渲染成一个虚拟 Node.它的定义在 src/core/instance/render.js 文件中: Vue.prototype._ ...

  2. 回形数字矩阵(Java)

    将矩阵从里到外分为多层,每一层都是一个口字型数字序列,方向都是顺时针/逆时针,由此我们可以将问题分解为相同的子问题来解决 回形矩阵概述 ☃ 回形矩阵有n行n列 ☃ 数字按顺时针或者逆时针递增 **使用 ...

  3. C语言链表头插法逆向输出

    输入:1 2 3 4 5 -1 输出:5 4 3 2 1 此题考查头链表的创建之一 :头插法.所谓头插法是从一个空链表开始,重复读入数据,生成新结点,将读入的数据存放新结点的数据域中,然后讲新结点插入 ...

  4. 手机内存卡RAW无法格式化的解决办法

    突然出现这个问题,这是麻烦: 网上找了各种办法:什么软件修复,disk等修复,创建新磁盘,新扇到,win自动修复啊:开始----运行框中输入      :convert X: /fs:FAT(X为电脑 ...

  5. java 字符+操作,字符串+操作

    字符额 “+” 操作 是拿字符在计算机底层对应的数值来进行计算的 ‘A’ = 65 A-Z是连续的 'a' = 97 a-z是连续的 '0' = 48 0-9是连续的 算数表达式中包含多个基本数据类型 ...

  6. 用Object.prototype.toString.call(obj)检测对象类型原因分析

    用Object.prototype.toString.call(obj)检测对象类型原因分析  更新时间:2018年10月11日 08:46:33   投稿:laozhang    我要评论   在本 ...

  7. 修改linux的MAC地址

    命令修改 步骤如下,但不唯一: 1.临时性的修改: ①依次输入以下命令: /sbin/ifconfig eth0 down /sbin/ifconfig eth0 hw ether 00:0C:29: ...

  8. 快速将Navicat中数据表信息导出

    1.使用navicat工具  2.新建查询  SELECT COLUMN_NAME 字段名, COLUMN_TYPE 数据类型, DATA_TYPE 字段类型, CHARACTER_MAXIMUM_L ...

  9. codeforces div2_603 F. Economic Difficulties(树dfs预处理+dp)

    题目连接:http://codeforces.com/contest/1263/problem/F 题意:有n个设备,上和下分别连接着一颗树,上下两棵树每棵树的叶子节点连接一个设备,两棵树的根节点都是 ...

  10. Maven项目中配置文件导出问题

    1.将该设置写在pom.xml中 <build> <resources> <resource> <directory>src/main/resource ...