「题解」 [CQOI2018]破解D-H协议

2023-10-24 00:59
文章标签 协议 破解 题解 cqoi2018

本文主要是介绍「题解」 [CQOI2018]破解D-H协议,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

人生中第一道紫题,写一篇题解纪念一下。

BSGS

BSGS(拔山盖世,北上广深 )是什么呢?

它是一种能够在 O ( n ) O(\sqrt n\space) O(n  )的时间复杂度内求解类似于 a x ≡ b ( m o d p ) a^x \equiv b \pmod{p} axb(modp)的算法。

首先,我们设 x = i p − j x=i\sqrt p-j x=ip j,其中 i , j ∈ [ 0 , p ] i,j\in [0,\sqrt p\space] i,j[0,p  ]

那么这个式子就变成了 a i p − j ≡ b ( m o d p ) a^{i\sqrt p-j} \equiv b\pmod p aip jb(modp)

两边同时乘上 a j a^j aj,很显然,等式变成了

a i p ≡ b a j ( m o d p ) a^{i\sqrt p} \equiv ba^j\pmod p aip baj(modp)

到了这一步,我们就可以先枚举 j j j,每次把 b a j m o d p ba^j\bmod p bajmodp存入哈希表。

然后再枚举 i i i,在哈希表中查找 a i p a^{i\sqrt p} aip ,如果找到了,就说明这个等式成立, x x x就应该是 i p − j i\sqrt p-j ip j,如果枚举完了也没找着,就说说明这个等式不成立。

在这个过程中,我们仅仅枚举了两次,时间复杂度只有区区的 O ( n ) O(\sqrt n\space) O(n  )

题目大意

看起来这个题目很复杂,但其实就是一个BSGS的模板。

简化一下题意,题目告诉你 g a m o d p g^a\bmod p gamodp g b m o d p g^b\bmod p gbmodp,让你求 g a b m o d p g^{ab}\bmod p gabmodp

观察一下,我们发现
g a b m o d p g^{ab}\bmod p gabmodp = ( g a ) b m o d p =(g^a)^b\bmod p =(ga)bmodp = ( g a m o d p ) b m o d p =(g^a\bmod p)^b\bmod p =(gamodp)bmodp = A b m o d p = A^b\bmod p =Abmodp

也就是说,只要我们把 b b b求出来,那就万事大吉了。

那么如何求 b b b呢?

观察发现:

B = g b m o d P B=g^b\bmod P B=gbmodP B ≡ g b ( m o d P ) B \equiv g^b\pmod P Bgb(modP) g b ≡ B ( m o d P ) g^b \equiv B\pmod P gbB(modP)

这不就是BSGS的模板吗?

我们可以用BSGS求出 b b b,然后把用 b b b求出 A b m o d p A^b\bmod p Abmodp

有了这个思路,我们就可以开始写代码了!

代码:

#include <bits/stdc++.h>
using namespace std;
int g,n,p;//在最开始就定义三个全局变量
int qpow(int a,int b){//快速幂模板int res=1;while(b){if(b&1) res=(a*res)%p;a=(a*a)%p;b>>=1;}return res;
}
int BSGS(int b){map<int,int>m;//哈希表可以用map代替int t=ceil(sqrt(p));//记得要向上取整for(int i=1;i<=t;i++) m[b*qpow(g,i)%p]=i;//枚举j,存入哈希表中for(int i=1;i<=t;i++){int k=qpow(g,i*t)%p;if(m[k]) return i*t-m[k];//如果在哈希表中找到了这个值,就说明找到了b}return -1;//如果没有找到,就说明无解
}int main(){cin>>g>>p>>n;for(int i=1;i<=n;i++){int A,B;cin>>A>>B;int b=BSGS(B);//用BSGS求出bcout<<qpow(A,b)%p<<endl;//用快速幂求出K}return 0;
}

如果把这份代码提交到洛谷上,那么就会出现

请添加图片描述
万紫千红的场面。

我们可以尝试着开longlong。

#define int long long

提交后发现

请添加图片描述

WA没了,就变成了tle。

我们可以使用printfscanf

请添加图片描述

优化了却没有完全优化。

抱着侥幸的心理,我开了O2,结果发现。
请添加图片描述

这玄学的数据!

完整代码(记得开O2):

#include <bits/stdc++.h>
#define int long long
using namespace std;
int g,n,p;//在最开始就定义三个全局变量
int qpow(int a,int b){//快速幂模板int res=1;while(b){if(b&1) res=(a*res)%p;a=(a*a)%p;b>>=1;}return res;
}
int BSGS(int b){map<int,int>m;//哈希表可以用map代替int t=ceil(sqrt(p));//记得要向上取整for(int i=1;i<=t;i++) m[b*qpow(g,i)%p]=i;//枚举j,存入哈希表中for(int i=1;i<=t;i++){int k=qpow(g,i*t)%p;if(m[k]) return i*t-m[k];//如果在哈希表中找到了这个值,就说明找到了b}return -1;//如果没有找到,就说明无解
}signed main(){scanf("%lld%lld%lld",&g,&p,&n);for(int i=1;i<=n;i++){int A,B;scanf("%lld%lld",&A,&B);int b=BSGS(B);//用BSGS求出bprintf("%lld\n",qpow(A,b)%p);//用快速幂求出K}return 0;
}

这篇关于「题解」 [CQOI2018]破解D-H协议的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/271637

相关文章

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

Java对接MQTT协议的完整实现示例代码

《Java对接MQTT协议的完整实现示例代码》MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛,:本文主要介绍Ja... 目录前言前置依赖1. MQTT配置类代码解析1.1 MQTT客户端工厂1.2 MQTT消息订阅适配器1.

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

Linux中的HTTPS协议原理分析

《Linux中的HTTPS协议原理分析》文章解释了HTTPS的必要性:HTTP明文传输易被篡改和劫持,HTTPS通过非对称加密协商对称密钥、CA证书认证和混合加密机制,有效防范中间人攻击,保障通信安全... 目录一、什么是加密和解密?二、为什么需要加密?三、常见的加密方式3.1 对称加密3.2非对称加密四、

如何在Spring Boot项目中集成MQTT协议

《如何在SpringBoot项目中集成MQTT协议》本文介绍在SpringBoot中集成MQTT的步骤,包括安装Broker、添加EclipsePaho依赖、配置连接参数、实现消息发布订阅、测试接口... 目录1. 准备工作2. 引入依赖3. 配置MQTT连接4. 创建MQTT配置类5. 实现消息发布与订阅

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Nginx中配置HTTP/2协议的详细指南

《Nginx中配置HTTP/2协议的详细指南》HTTP/2是HTTP协议的下一代版本,旨在提高性能、减少延迟并优化现代网络环境中的通信效率,本文将为大家介绍Nginx配置HTTP/2协议想详细步骤,需... 目录一、HTTP/2 协议概述1.HTTP/22. HTTP/2 的核心特性3. HTTP/2 的优

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

Qt 中集成mqtt协议的使用方法

《Qt中集成mqtt协议的使用方法》文章介绍了如何在工程中引入qmqtt库,并通过声明一个单例类来暴露订阅到的主题数据,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一,引入qmqtt 库二,使用一,引入qmqtt 库我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台

Java如何接收并解析HL7协议数据

《Java如何接收并解析HL7协议数据》文章主要介绍了HL7协议及其在医疗行业中的应用,详细描述了如何配置环境、接收和解析数据,以及与前端进行交互的实现方法,文章还分享了使用7Edit工具进行调试的经... 目录一、前言二、正文1、环境配置2、数据接收:HL7Monitor3、数据解析:HL7Busines