BZOJ_5296_[Cqoi2018]破解D-H协议_BSGS
BZOJ_5296_[Cqoi2018]破解D-H协议_BSGS
Description
Input
Output
Sample Input
3
27 16
21 3
9 26
Sample Output
21
25
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <map>
#include <math.h>
using namespace std;
typedef long long ll;
map<ll,int>mp;
void exgcd(ll a,ll b,ll &x,ll &y,ll &p) {
if(!b) {x=1; y=0; p=a; return ;}
exgcd(b,a%b,y,x,p);
y-=a/b*x;
}
ll qp(ll x,ll y,ll p) {
ll re=1;
while(y) {
if(y&1ll) re=re*x%p;
x=x*x%p;
y>>=1ll;
}
return re;
}
ll BSGS(ll a,ll b,ll n) {
if(n==1) if(!b) return a!=1;else return -1;
if(b==1) if(a) return 0;else return -1;
if(a%n==0) if(!b) return 1;else return -1;
ll m=ceil(sqrt(n)),d=1,base=1;
mp.clear();
int i;
for(i=0;i<m;i++) {
if(!mp.count(base)) mp[base]=i;
base=base*a%n;
}
for(i=0;i<m;i++) {
ll x,y,s;
exgcd(d,n,x,y,s);
x=(x*b%n+n)%n;
if(mp.count(x)) return i*m+mp[x];
d=d*base%n;
}
return -1;
}
int main() {
ll g,p,n,A,B,a,b;
scanf("%lld%lld%lld",&g,&p,&n);
while(n--) {
scanf("%lld%lld",&A,&B);
a=BSGS(g,A,p);
printf("%lld\n",qp(B,a,p));
}
}
BZOJ_5296_[Cqoi2018]破解D-H协议_BSGS的更多相关文章
- BZOJ5296 CQOI2018 破解D-H协议 【BSGS】
		BZOJ5296 CQOI2018Day1T1 破解D-H协议 Description Diffie-Hellman密钥交换协议是一种简单有效的密钥交换方法.它可以让通讯双方在没有事先约定密钥(密码) ... 
- [CQOI2018]破解D-H协议
		嘟嘟嘟 这不就是个bsgs板儿嘛. 顺便就复习了一下bsgs和哈希表. 头一次觉得我的博客这么好用,一下就懂了:数论学习笔记之高次不定方程 这里再补充几点: 1.关于这一段代码: int S = sq ... 
- BZOJ5296 [CQOI2018] 破解D-H协议 【数学】【BSGS】
		题目分析: 裸题. 代码: #include<bits/stdc++.h> using namespace std; typedef long long ll; ; #define mp ... 
- 2018.12.18 bzoj5296: [Cqoi2018]破解D-H协议(bsgs)
		传送门 bsgsbsgsbsgs基础题. 考虑到给的是原根,因此没无解的情况. 于是只需要每次把a,ba,ba,b解出来. 然后可以通过预处理节省一部分时间. 代码: #include<bits ... 
- LG4454 【[CQOI2018]破解D-H协议】
		先谈一下BSGS算法(传送门) 但是上面这位的程序实现比较繁琐,看下面这位的. clover_hxy这样说 bsgs算法,又称大小步算法(某大神称拔山盖世算法). 主要用来解决 A^x=B(mod C ... 
- BZOJ 5296: [Cqoi2018]破解D-H协议(BSGS)
		传送门 解题思路 \(BSGS\)裸题??要求的是\(g^a =A (mod\) \(p)\),设\(m\)为\(\sqrt p\),那么可以设\(a=i*m-j\),式子变成 \[ g^{i*m-j ... 
- P4454 [CQOI2018]破解D-H协议
		链接 这题并不难只是需要把题读懂 - By ShadderLeave 一句话题意 给定两个数 \(p\)和\(g\),有\(t\)组询问,每组询问给出\(A\)和\(B\) 其中 A = \(g^a ... 
- 破解使用SMB协议的Windows用户密码:acccheck
		一.工作原理 Acccheck是一款针对微软的SMB协议的探测工具(字典破解用户名和密码),本身不具有漏洞利用的能力. SMB协议:SMB(Server Message Block)通信协议主要是作为 ... 
- Linux 利用hosts.deny 防止暴力破解ssh(转)
		一.ssh暴力破解 利用专业的破解程序,配合密码字典.登陆用户名,尝试登陆服务器,来进行破解密码,此方法,虽慢,但却很有效果. 二.暴力破解演示 2.1.基础环境:2台linux主机(centos 7 ... 
随机推荐
- .net找List1和List2的差集
			有个需求是找两个自定义类泛型集合的差集: class Person { public string Name{get; set;} public string Country{get; set;} } ... 
- 简单验证码的识别:Bitmap类的使用
			验证码的智能识别是一项比较复杂的工作,甚至需要掌握点图像学的知识. 当然对于写程序的来说不用那么深入,只需要掌握几个常规步骤就行了. 验证码图像识别步骤:1.获取图像 2.清除边框 3.灰度处理 4. ... 
- 大数据技术生态圈形象比喻(Hadoop、Hive、Spark 关系)
			[摘要] 知乎上一篇很不错的科普文章,介绍大数据技术生态圈(Hadoop.Hive.Spark )的关系. 链接地址:https://www.zhihu.com/question/27974418 [ ... 
- Day  网络协议介绍 简单通信的实现
			比如说实现两个手机之间的通信,需要做的几部: 服务端: 1,买手机 2,插卡 3,开机 4,等电话链接 5,基于建立的链接,收发协议 6,挂电话 7,关机 import socket #买手机 pho ... 
- hadoop 2.x安装:完全分布式安装
			1. 安装环境 本文使用三台CentOS6.4虚拟机模拟完全分布式环境.前五个过程和hadoop1.x安装相同 1.1. 安装环境 项目 参数 主操作系统 Windows 10 64 bit,8GB内 ... 
- 移动端h5实现复制功能
			首先遇到这个需求是就各种百度,但是发现基本都是用js实现,而且兼容性还非常不好. 但是在寻觅和尝试的过程中,发现只需要css代码也可以完全实现的,对需要复制内容的标签加上下面这几行代码就可以了. -w ... 
- IE条件注释,为IE单独写js
			<!--[if IE ]> <body class="ie"> <![endif]--> <!--[if !IE]>--> & ... 
- java(二、基础语法和基本数据类型)
			Java 基础语法 一个Java程序可以认为是一系列对象的集合,而这些对象通过调用彼此的方法来协同工作.下面简要介绍下类.对象.方法和实例变量的概念. 对象:对象是类的一个实例,有状态和行为.例如,一 ... 
- spring boot之从零开始开发自己的网站
			概述 首先要感谢两位大神,该项目的想法来源自tale和MyBlog,本项目的想法. 做了一些改造,增加了一些功能和一些代码的重构,并且更换了博客主题. 关于项目,对于开发的练手项目,能够工程化,严谨一 ... 
- PAT1012:The Best Rank
			1012. The Best Rank (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue To eval ... 
