古典恺撒移位密码破解

article/2025/9/24 21:39:04

1. cipher text

bmjs dtz uqfd ymj lfrj tk ymwtsjx dtz bns tw dtz inj ymjwj nx st rniiqj lwtzsi

刚看到需要解密的文本,就觉得它很像移位密码,于是开始试了一下。
源代码:
求最大公因数:Arithmetic.java

public class Arithmetic {int x = 0;int y = 0;public int euclid(int a,int b){int first,second;first = a;second = b;int temp;if(first<second){temp = first;first = second;second = temp;}while(first%second!=0){temp = first%second;first = second;second = temp;}return second;}
}

移位密码的解密:Affine.java

class Affine {String deciphering(String s, int a, int b){// 解密的实现char[] ch = s.toCharArray();int length = ch.length;// 密文长度int[] in = new int[length];for (int i = 0; i < ch.length; i++) {if(ch[i] == ' '){  //如果是空格就不用解密,直接跳过}else {in[i] = ch[i] - 97;// 利用ascii变成0-25数字in[i] = ((in[i] - b) * a) % 26;  // 解密if (in[i] < 0) {in[i] += 26;}ch[i] = (char) (in[i] + 97);// 将数字变成字母}}return String.valueOf(ch);// 将字符串数字变成String类型的字符串,返回}
}

主类:Test.java

public class Test {public static void main(String[] args) {Arithmetic arithmetic = new Arithmetic();final int MOD = 26;int [] gcd = new int[12];int m = 0;String out = null;for(int i=1;i<MOD;i++){if((arithmetic.euclid(i,MOD)) == 1) {   //求与26互素的数gcd[m] = (arithmetic.euclid_2(i,MOD)+26)%26; //求这些数mod26的逆,并把它加入gcd数组m++;}}Scanner input = new Scanner(System.in);System.out.println("请输入需要解密的密文:");String s = input.nextLine();// 输入密文Affine affine = new Affine();int k =1;for(int i=0;i<12;i++) {for (int j = 0; j < 26; j++) {out = affine.deciphering(s, gcd[i], j);System.out.println("第"+k+"条明文为:"+out);k++;}}}
}

实验结果截图:
在这里插入图片描述

最后成功破解了由仿射密码加密的密文,得到了明文when you play the game of thrones you win or you die there is no middle ground。


http://chatgpt.dhexx.cn/article/o0aAZbUr.shtml

相关文章

移位密码(凯撒密码)

一、移位密码(凯撒密码) 移位密码是一种简单的加密方法&#xff0c;它通过将明文中的每个字符按照一定规则向左或向右移动若干位来生成密文。移位密码通常使用偏移量来确定每个字符移动的位数。 二、加密解密 1. 移位加密 移位加密算法将明文中的每个字符按照一定规则向左或…

凯撒密码(移位密码)

凯撒密码&#xff08;移位密码&#xff09; 移位密码是一种古典密码&#xff0c;实际上是替换密码的一个特例&#xff0c;它有很严格的数学定义 // 移位密码 import java.util.Scanner;public class Caesar {public static void main(String[] args) {System.out.println(&q…

大端模式和小端模式

一.概念 大端模式&#xff08;Big-endian&#xff09;&#xff1a;高位字节排放在内存的低地址端&#xff0c;低位字节排放在内存的高地址端&#xff0c;即正序排列&#xff0c;高尾端&#xff1b; 小端模式&#xff08;Little-endian&#xff09;&#xff1a;低位字节排放在…

数据存储:大端和小端

目录 字节序 大端和小端 大端小端测试 写入测试 字节码文件的大小端 前面说到&#xff0c;像C/C这类语言编写的程序&#xff0c;它们被编译后&#xff0c;直接转换成了对应平台上的可被CPU直接运行的机器指令&#xff0c;转换之后&#xff0c;原本语言中的数据结构&#x…

大端和小端传输字节序

大端和小端 在计算机中是以字节为单位&#xff0c;每一个地址对应一个字节&#xff0c;一个字节8bit。在C中&#xff0c;除了8bit的char以外&#xff0c;还有16bit的short&#xff0c;32位的int&#xff0c;64位long&#xff0c;当然具体要由编译器决定&#xff0c;可以通过si…

大端字节序和小端字节序

字节序&#xff0c;即字节在电脑中存放时的序列与输入&#xff08;输出&#xff09;时的序列是先到的在前还是后到的在前。 -- 转自&#xff1a;字节序_百度百科 (baidu.com) 在几乎所有的平台上&#xff0c;多字节对象都被存储为连续的字节序列。例如在 C 语言中&#xff0c;一…

简单理解大端小端

大端和小端是计算机写内存的习惯。就如人类写文章时的顺序一般&#xff0c;现代人从左往右&#xff0c;古人却是竖书成行&#xff08;自上而下写满一行后&#xff0c;再自右向左换行。&#xff09;&#xff1b;有些计算机规定从左往右写内存&#xff0c;有些规定从右往左写内存…

java 为什么用大端_Java中的大端和小端

Java整型的字节序是() A.Little-Endian(小端) B.Big-Endian(大端) C.由运行程序的CPU决定 D.由编译程序的CPU决定 对于大小端&#xff0c;我估计肯定有很多开发人员跟我一样都没听过 由于Java是跨平台的&#xff0c;JVM为我们屏蔽了大量的底层细节和复杂性&#xff0c;导致在平…

存储模型:大端和小端

前言&#xff1a; 计算机操作系统中存储信息都是以字节为单位&#xff0c;每个地址单元对应 1 个字节。 1 个字节为 8 bits&#xff0c;对于某些32 位处理器而言&#xff0c;char类型数据占用 1 个字节的空间&#xff0c;short 占用2个字节&#xff0c;int 占用4个字节。而这…

操作系统之大端小端

1. 什么是大端,什么是小端: 所谓的大端模式&#xff0c;是指数据的低位保存在内存的高地址中&#xff0c;而数据的高位&#xff0c;保存在内存的低地址中&#xff1b; 所谓的小端模式&#xff0c;是指数据的低位保存在内存的低地址中&#xff0c;而数据的高位保存在内存的高地…

二进制、16进制、大端小端

16进制的使用 在开发过程中&#xff0c;写文件是常有的事&#xff0c;如果写的内容是文本&#xff0c;随便用一个记事本软件打开即可查看内容是否正确&#xff0c;如果写的是音频文件&#xff0c;就要用音频播放器来查看&#xff0c;如果是视频文件&#xff0c;就要用视频播放…

网络传输大端序_大端、小端与网络字节序

大端(Big-Endian)&#xff0c;小端(Little-Endian)以及网络字节序的概念在编程中经常会遇到。网络字节序(Network Byte Order)一般是指大端(Big-Endian&#xff0c;对大部分网络传输协议而言)传输&#xff0c;大端小端的概念是面向多字节数据类型的存储方式定义的&#xff0c;小…

677-大端模式和小端模式详解

1、大端和小端核心是什么&#xff1f; 大端模式和小端是实际的字节顺序和存储的地址顺序对应关系的两种模式&#xff0c;总结如下&#xff1a; 大端模式&#xff1a;低地址对应高字节 小端模式&#xff1a;低地址对应低字节 不管是大端还是小端模式&#xff0c;我们在读取和存…

大端小端详解

转载&#xff1a;大端小端详解 1>"大端" "小端"的来源 关于大端小端名词的由来&#xff0c;网传有一个有趣的故事&#xff0c;可以追溯到1726年的Jonathan Swift的《格列佛游记》&#xff0c;其中一篇讲到有两个国家因为吃鸡蛋究竟是先打破较大的一端…

大端序发送数据

需要发送数字 151510 大端序发送就是 &#xff1a;00 02 4F D6 string smallData textBox1.Text;//小端数据if (smallData ""){MessageBox.Show("请输入初始里程", "错误",MessageBoxButtons.OK, MessageBoxIcon.Exclamation);textBox1.Text …

c语言之大端小端问题

这就是字节序问题&#xff1a;数据在计算机内存中存储或者网络传输时各字节的存储顺序 通常来说就分为两种情况&#xff1a; 一种是大端(big-endian)&#xff1a;高字节(高位)存放在低地址&#xff0c;低字节(低位)存在高地址 另外一种小端(little-endian)&#xff1a;高位存放…

数据存储:大端小端

文章目录 问题起源大端小端大端小端优劣符合人类阅读方式数据类型转换符号位的识别 参考资料 曾经辨析和了解过大端小端&#xff0c;但是到了实际应用中还是比较模糊。整理一些资料文章&#xff0c;在此记录。 问题起源 在计算机的使用以及现代很多的嵌入式设备中&#xff0c;…

大端与小端

一.大小端介绍 “大端”和“小端”表示多字节值的哪一端存储在该值的起始地址处。小端存储在起始地址处&#xff0c;即是小短字节序&#xff1b;大端存储在起始地址处&#xff0c;即是大端字节序。 大端存储模式&#xff1a;数据的低位保存在内存中的高地址中&#xff0c;数据…

大端和小端的含义及判断代码

1、概述 在计算机系统中&#xff0c;数据都是以字节进行存储的&#xff0c;每个地址单元对应一个字节&#xff0c;每个字节都是8位&#xff08;bit&#xff09;。但是C除了char和bool之外&#xff0c;还有其它多字节类型。怎样存储多字节的数据就分为了大端和小端。字节序只和…

C语言基础 —大端和小端

大端和小端 1、什么是大端和小端2、为什么会有大端和小端3、怎样判断是大端还是小端 1、什么是大端和小端 大端模式&#xff1a;就是 高位字节 存放在内存的 低地址端&#xff0c;低位字节 存放在内存的 高地址端 小端模式&#xff1a;就是 低字节存 放在内存的 低地址端&…