一道不错的题目,借鉴了网上的代码,用了拓展欧几里得算法求逆元,再用快速乘求每次a的余数,再快速幂对余数进行幂运算。

 #include <bits/stdc++.h>
using namespace std;
long long n=;
long long d=;
long long c=;
long long p=;
long long q=;
long long e=;
long long phi=(p-)*(q-);
void Ex_gcd(long long a,long long b,long long &x,long long &y)     // 欧几里得算法求逆元
{
if(b==)
{
x=;
y=;
return ;
}
long long x1,y1;
Ex_gcd(b,a%b,x1,y1);
x=y1;
y=x1-(a/b)*y1;
}
long long quickmul(long long a,long long b)    //快速乘求每次的余数
{
long long sum=;
while(b)
{
if(b%==)
sum=(sum+a)%n;
a=(a+a)%n;
b=b/;
}
return sum;
}
long long quickmod(long long a,long long b)          //快速幂
{
long long ans=;
while(b)
{
if(b%==)//末位是1;
ans=quickmul(ans,a);//这是直接的回溯法,从最后一位起,如果,如果最后一位是1,则乘a,然后在进行乘以它本身,以为乘1之后一定为偶数,也就是b/2;
a=quickmul(a,a);
b=b/;
}
return ans;
}
int main()
{
long long x,y;
Ex_gcd(d,(q-)*(p-),x,y);
x=(x+phi)%phi;    //让x为正
printf("e=%lld\n",x);
printf("ans=%lld\n",quickmod(c,e));
return ;
}

如果第一次接触扩展欧几里得算法,可以看下面几篇博文,我靠着这几篇逐步弄懂代码的,虽然c++不太会。

按着顺序看,反正我是这么过来了,前提是得知道欧几里得算法,呕心沥血。

https://note.youdao.com/ynoteshare1/index.html?id=3f0c60d22c0a3016642df397ded87a2f&type=note

https://cloud.tencent.com/developer/article/1433267

https://blog.csdn.net/stray_lambs/article/details/52133141

//     ---------更新-----------,java 版本的代码

//                  --2020.2.10  (武汉加油!)

     

 public class Main {

 //    static BigInteger n = new BigInteger("1001733993063167141");
static long n = 1001733993063167141L; //java 大数转为long,记得后面最后面那个是l/L
static long d=212353;
static long c=20190324;
static long p=891234941;
static long q=1123984201;
// static BigInteger e = new BigInteger("823816093931522017");
static long phi=(p-1)*(q-1);
static long e = 1;
static long x1 = 0, y1 = 0;
static long ans = 1; //求解p和q的
// static long p = 2;
// static long q = 0;
// public static void qiue() {
// while(n % p != 0)p++;
// q = n / p;
// } public static long quickmod(long a, long b) { // ---分界线---
long x = 0;
while(b != 0) {
if(b % 2 == 1) {
x = (x + a) % n;
}
a = (a + a) % n;
b /= 2;
}
return x;
}
// 用快速幂求模,每次求模后余数相乘,得到最后的答案
// 每当要用到乘法时,用快速乘,再模,求余数 public static void quickmul(long c, long e) {
while(e != 0) {
if(e % 2 == 1) {
ans = quickmod(ans, c);
}
e /= 2;
c = quickmod(c, c);
}
} // ---分界线--- public static void gcd(long i, long j, long a, long b) { //欧几里得扩展求乘法逆元
if(j == 0) {
x1 = 1;
y1 = 0;
return;
} gcd(j, i % j, x1, y1);
long temp = x1;
x1 = y1;
y1 = temp - i / j * y1;
e = x1;
return ; } public static void main(String[] args){
gcd(d, phi, x1, y1);
e = (e + phi) % phi;
System.out.println(e);
quickmul(c, e);
System.out.print(ans); }
}

e的答案是:823816093931522017

最后的答案是:579706994112328949

           

第十届蓝桥杯 RSA解密(C++/ java)的更多相关文章

  1. 2019年第十届蓝桥杯c++A组java/c++组题解

    #include<iostream> #include<vector> using namespace std; vector <int > vec; long l ...

  2. 第十届蓝桥杯省赛JavaB组个人题解

    前言 以下的第十届蓝桥杯Java B组省赛的题目题解只是我个人的题解,提供一些解题思路,仅作参考,如有错误,望大家指出,不甚感激,我会及时更改. 试题 A: 组队 ----- 答案:490 [问题描述 ...

  3. 第十届蓝桥杯2019年C/C++ 大学B组省赛试题

    2019年第十届蓝桥杯大赛软件类省赛C/C++大学B组 试题 A:组队 本题总分:5分 [问题描述] 作为篮球队教练,你需要从以下名单中选出 1号位至 5号位各一名球员, 组成球队的首发阵容. 每位球 ...

  4. 2019第十届蓝桥杯C++B组题解(赛后重写的,不确保答案正确性,仅供参考)

    先说一下这次的感受吧,我们考场比较乱,开始比赛了,还有的电脑有故障,(向这些人发出同情),第一次认真参加比赛,真正比赛的时候感觉没有那么正式,很乱,各种小问题,(例如博主就没找到题目在哪里,找到后又不 ...

  5. 2019年第十届蓝桥杯【C++省赛B组】

    试题 A: 组队 本题总分:5 分 作为篮球队教练,你需要从以下名单中选出 1 号位至 5 号位各一名球员,组成球队的首发阵容.每位球员担任 1 号位至 5 号位时的评分如下表所示.请你计算首发阵容 ...

  6. 第十届蓝桥杯JavaB组省赛真题

    试题 A: 组队 本题总分:5 分 [问题描述] 作为篮球队教练,你需要从以下名单中选出 1 号位至 5 号位各一名球员, 组成球队的首发阵容. 每位球员担任 1 号位至 5 号位时的评分如下表所示. ...

  7. 第十届蓝桥杯JavaC组省赛真题

    试题 A: 求和 本题总分:5 分 [问题描述] 小明对数位中含有 2.0.1.9 的数字很感兴趣,在 1 到 40 中这样的数包 括 1.2.9.10 至 32.39 和 40,共 28 个,他们的 ...

  8. Java实现第十届蓝桥杯JavaC组第十题(试题J)扫地机器人

    扫地机器人 时间限制: 1.0s 内存限制: 512.0MB 本题总分:25 分 [问题描述] 小明公司的办公区有一条长长的走廊,由 N 个方格区域组成,如下图所 示. 走廊内部署了 K 台扫地机器人 ...

  9. Java实现第十届蓝桥杯外卖店优先级

    试题 G: 外卖店优先级 时间限制: 1.0s 内存限制: 512.0MB 本题总分:20 分 [问题描述] "饱了么"外卖系统中维护着 N 家外卖店,编号 1 ∼ N.每家外卖店 ...

随机推荐

  1. OBS输出设置

    参数建议来自虎牙 https://help.huya.com/284 3.输出: 1)编码器中x264相当于虎牙直播中的CPU H.264编码,NVENC H.264相当于虎牙直播中的NVIDIA H ...

  2. 人工神经网络(从原理到代码) Step 01 感知器 梯度下降

    版权声明: 本文由SimonLiang所有,发布于http://www.cnblogs.com/idignew/.如果转载,请注明出处,在未经作者同意下将本文用于商业用途,将追究其法律责任. 感知器 ...

  3. Web--Utils

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  4. where、having区别

    where  <<   group by   <<   having where筛选是在分组之前筛选,筛选完之后再group by having是分组之后再筛选,筛选完之前先g ...

  5. 「模板」可持久化 HFQ-Treap

    老师用的是静态数组的写法,开了很多数组- 其实个人更倾向于 struct 或者用 class 封装起来. 但是鉴于太难打 好吧,是我懒得打. 然后就借鉴了老师的模板,写出了属于自己的 压行 风格. 代 ...

  6. nginx访问目录是没加/的重定向控制

    static 模块提供了root与alias功能:发现目标是目录时:但URI末尾未加/时:会返回301重定向:重定向后会加/ 指令 Syntax: server_name_in_redirect on ...

  7. win10上安装mysql8(installer方式)并创建用户开启远程连接

    1.进去mysql官网,下载mysql安装工具: 2.运行下载的mysql-installer-community-8.0.17.0.msi,一次往下执行就好了,以下是几个注意的点: 后面还有个地方就 ...

  8. F: Horse Pro 马走棋盘 BFS

    F: Horse Pro 豆豆也已经开始学着玩象棋了,现在豆豆已经搞清楚马的走法了,但是豆豆不能确定能否在 100 步以内从一个点到达另一个点(假设棋盘无限大). Input 第一行输入两个整数 x1 ...

  9. 孤荷凌寒自学python第103天认识区块链017

    [主要内容] 今天继续分析从github上获取的开源代码怎么实现简单区块链的入门知识,共用时间25分钟. (此外整理作笔记花费了约34分钟) 详细学习过程见文末学习过程屏幕录像. 今天所作的工作是进一 ...

  10. 工作脚本拆分xml文并重定向数据

    sed -n '/<N/p' CM-ENB-SRVIDENTIFYBASEBSRTDD-2C-ALLV2.9.0-20191209020003.xml.gz.xml|awk -F"&g ...