看了Po神的题解一下子就懂了A了!

不过Po神的代码出锅了…solve中"d-temp"并没有什么用QwQQwQQwQ…应该把模数除以p^temp次方才行.

来自BZOJ讨论板的hack数据

hack data

1 5 3125 7812

正确输出应该是625, 但是很多人输出3125…

CODE

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL INF = 1e15;
inline LL qpow(LL a, LL b, LL c) {
LL re = 1;
while(b) {
if(b&1) re = re * a % c;
a = a * a % c; b >>= 1;
}
return re;
}
LL gcd(LL a, LL b) { return b ? gcd(b, a%b) : a; }
void exgcd(LL a, LL b, LL &x, LL &y) {
if(!b) { x = 1, y = 0; return; }
exgcd(b, a%b, y, x); y -= x*(a/b);
}
int prime[100], cnt;
inline void Factor(int N) {
cnt = 0;
for(int i = 2; i*i <= N; ++i)
if(N % i == 0) {
prime[++cnt] = i;
while(N % i == 0) N /= i;
}
if(N > 1) prime[++cnt] = N;
}
inline int Get_g(int p, int phi) { //找原根
Factor(phi);
for(int g = 2; ; ++g) {
bool flg = true;
for(int i = 1; i <= cnt; ++i)
if(qpow(g, phi/prime[i], p) == 1)
{ flg = 0; break; }
if(flg) return g;
}
}
map<int, int>myhash;
inline LL Baby_Step_Giant_Step(LL a, LL b, LL p) {
myhash.clear(); int m = int(sqrt(p) + 1);
LL base = b;
for(int i = 0; i < m; ++i) {
myhash[base] = i;
base = base * a % p;
}
base = qpow(a, m, p); LL tmp = 1;
for(int i = 1; i <= m+1; ++i) {
tmp = tmp * base % p;
if(myhash.count(tmp))
return i*m - myhash[tmp];
}
return -1;
}
inline LL solve(LL a, LL b, LL p, LL d, LL p_d) {
b %= p_d;
if(!b) return qpow(p, d-((d-1)/a+1), INF);
LL temp = 0;
while(b % p == 0) b /= p, ++temp, p_d /= p;
if(temp % a) return 0;
LL phi = p_d - p_d/p, g = Get_g(p_d, phi);
LL ind = Baby_Step_Giant_Step(g, b, p_d);
LL re = gcd(a, phi);
if(ind % re) return 0;
return re * qpow(p, temp-temp/a, INF);
}
int main() {
int T, a, b, k;
for(scanf("%d", &T); T; T--) {
scanf("%d%d%d", &a, &b, &k); k = k<<1|1;
LL ans = 1;
for(int i = 2; i*i <= k && ans; ++i)
if(k % i == 0) {
int d = 0, p_d = 1;
while(k % i == 0) k /= i, ++d, p_d *= i;
ans *= solve(a, b, i, d, p_d);
}
if(k > 1 && ans) ans *= solve(a, b, k, 1, k);
printf("%lld\n", ans);
}
}

BZOJ 2219 数论之神 (CRT推论+BSGS+原根指标)的更多相关文章

  1. BZOJ 2219: 数论之神

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2219 N次剩余+CRT... 就是各种奇怪的分类讨论.. #include<cstrin ...

  2. 【BZOJ】【2219】数论之神

    中国剩余定理+原根+扩展欧几里得+BSGS 题解:http://blog.csdn.net/regina8023/article/details/44863519 新技能get√: LL Get_yu ...

  3. 数论算法 剩余系相关 学习笔记 (基础回顾,(ex)CRT,(ex)lucas,(ex)BSGS,原根与指标入门,高次剩余,Miller_Rabin+Pollard_Rho)

    注:转载本文须标明出处. 原文链接https://www.cnblogs.com/zhouzhendong/p/Number-theory.html 数论算法 剩余系相关 学习笔记 (基础回顾,(ex ...

  4. BZOJ2219数论之神——BSGS+中国剩余定理+原根与指标+欧拉定理+exgcd

    题目描述 在ACM_DIY群中,有一位叫做“傻崽”的同学由于在数论方面造诣很高,被称为数轮之神!对于任何数论问题,他都能瞬间秒杀!一天他在群里面问了一个神题: 对于给定的3个非负整数 A,B,K 求出 ...

  5. bzoj2219: 数论之神

    #include <iostream> #include <cstdio> #include <cstring> #include <cmath> #i ...

  6. 【bzoj2219-数论之神】求解x^a==b(%n)-crt推论-原根-指标-BSGS

    http://www.lydsy.com/JudgeOnline/problem.php?id=2219 弄了一个晚上加一个午休再加下午一个钟..终于ac..TAT 数论渣渣求轻虐!! 题意:求解 x ...

  7. 数论入门2——gcd,lcm,exGCD,欧拉定理,乘法逆元,(ex)CRT,(ex)BSGS,(ex)Lucas,原根,Miller-Rabin,Pollard-Rho

    数论入门2 另一种类型的数论... GCD,LCM 定义\(gcd(a,b)\)为a和b的最大公约数,\(lcm(a,b)\)为a和b的最小公倍数,则有: 将a和b分解质因数为\(a=p1^{a1}p ...

  8. BZOJ2219 数论之神 数论 中国剩余定理 原根 BSGS

    原文链接https://www.cnblogs.com/zhouzhendong/p/BZOJ2219.html 题目传送门 - BZOJ2219 题意 求同余方程 $x^A\equiv B \pmo ...

  9. luogu 2480 古代猪文 数论合集(CRT+Lucas+qpow+逆元)

    一句话题意:G 的 sigma d|n  C(n d) 次幂  mod 999911659 (我好辣鸡呀还是不会mathjax) 分析: 1.利用欧拉定理简化模运算 ,将上方幂设为x,则x=原式mod ...

随机推荐

  1. VMware Conveter Standalone agent 安装时出现Error 29190错误的解决办法

    官网上面找的: if it helps anyone else, i found a workaround for my particular issue. on the source machine ...

  2. sqarkSQL hiveSql

    查看数据库 show databases; 进入数据库 use 库名 查看表 show tables: select * from 表名 hdfs传输spark sql查询 hive找到指定路径sql ...

  3. Linux系列之putty远程登录

    在工作中,我们通常都是通过远程操作Linux服务器的,因此必须熟悉一些远程登录的软件,在此使用的是putty,在Windows上安装putty软件,通过该软件访问Linux主机. 1.远程登录步骤 1 ...

  4. docker CMD 和 ENTRYPOINT 区别

    昨天用Dockerfile来启动mongodb的集群,启动参数--replSet死活没执行,最后就决定研究一哈cmd和entrypoint.但是上网看了一些资料个人觉得讲的不好,还是没有说出根本的东西 ...

  5. jsp其实是一个java类

    我们打开tomcat的D:\Program_Files\apache-tomcat-8.0.32\work\Catalina\localhost\venus\org\apache\jsp, 当我们访问 ...

  6. C# 使用Emit实现动态AOP框架 进阶篇之异常处理

    目  录 C# 使用Emit实现动态AOP框架 (一) C# 使用Emit实现动态AOP框架 (二) C# 使用Emit实现动态AOP框架 (三) C# 使用Emit实现动态AOP框架 进阶篇之异常处 ...

  7. 使用.netcore部署window服务完成过程(使用nssm,Topshelf)

    一,新建.netcore控制台应用程序.本文使用.netcore2.2版本,结构如下 二,negut引用Topshelf.Log4Net,Topshelf 三,代码如下:1>Program.cs ...

  8. 【js】clientY pageY screenY layerY offsetY的区别

    clientY 指的是距离可视页面左上角的距离 pageY 指的是距离可视页面左上角的距离(不受页面滚动影响) screenY 指的是距离屏幕左上角的距离 layerY 指的是找到它或它父级元素中最近 ...

  9. 服务端相关知识学习(六)Zookeeper client

    Zookeeper的client是通过Zookeeper类提供的.前面曾经说过,Zookeeper给使用者提供的是一个类似操作系统的文件结构,只不过这个结构是分布式的.可以理解为一个分布式的文件系统. ...

  10. Springboot Hikari Centos 首次连数据库很慢

    前言: springboot项目默认使用了hikari作为数据库连接池,在开发机器上一切正常. 但是把程序部署到Centos7 x64上之后发现,每次首页登录的时候都要停顿几十秒. 于是,在程序启动后 ...