移位密码(凯撒密码)

article/2025/9/24 21:32:24

一、移位密码(凯撒密码)

移位密码是一种简单的加密方法,它通过将明文中的每个字符按照一定规则向左或向右移动若干位来生成密文。移位密码通常使用偏移量来确定每个字符移动的位数。

二、加密解密

1. 移位加密

移位加密算法将明文中的每个字符按照一定规则向左或向右移动若干位来生成密文。具体步骤如下:

  • 选择一个偏移量 k k k,确定每个字符需要向左移动还是向右移动。
  • 对于明文中的每个字符,根据偏移量将其向左或向右移动相应的位数,并将结果记录下来。
  • 将所有移位后的字符连接起来,得到密文。

例如,如果明文是 HELLO,偏移量为3,则加密后的密文就是 KHOOR(可结合下方字母数字表查看)。这里的偏移量表示字母移动的距离,当偏移量为正数时,字母向右移动;当偏移量为负数时,字母向左移动。

2. 移位解密

移位解密算法将密文中的每个字符按照与加密相反的规则向左或向右移动若干位来还原明文。具体步骤如下:

  • 选择一个偏移量 k k k,确定每个字符需要向左移动还是向右移动。
  • 对于密文中的每个字符,根据偏移量将其向左或向右移动相应的位数,并将结果记录下来。
  • 将所有移位后的字符连接起来,得到明文。

例如,如果密文是 KHOOR,偏移量为3,则解密后的明文就是 HELLO

3.其他表述

x是加密前的字符,y是加密后的字符。

对26取余的作用是确保加密和解密过程中使用的数字始终保持在0~25的范围内,从而实现正确的加密和解密操作。

加密: e ( x ) = x + k m o d 26 e(x)=x+k\bmod26 e(x)=x+kmod26

解密: d ( y ) = y − k m o d 26 d(y)=y-k\bmod26 d(y)=ykmod26

ABCDEFGHIJKLMNOPQRSTUVWXYZ
012345678910111213141516171819202122232425

三、python实现

# 定义一个加密函数,接收两个参数:待加密文本和偏移量[0~25]
def encrypt(text: str, s: int):result = ""# 遍历文本中的所有字符for char in text:# 判断字符是否为大写字母,如果是则将其加密if 65 <= ord(char) <= 90:result += chr((ord(char) + s - 65) % 26 + 65)# 判断字符是否为小写字母,如果是则将其加密elif 97 <= ord(char) <= 122:result += chr((ord(char) + s - 97) % 26 + 97)# 不是字母,则直接追加到结果字符串中else:result += charprint(f"{text}加密结果:{result},偏移量:{s}")# 定义一个解密函数,接收一个参数:待解密的密文
def decrypt(ciphertext: str):for s in range(26):result = ''for char in ciphertext:if 65 <= ord(char) <= 90:result += chr((ord(char) - s - 65) % 26 + 65)elif 97 <= ord(char) <= 122:result += chr((ord(char) - s - 97) % 26 + 97)else:result += charprint(f"偏移量为{s}时解密结果为:{result}")print('加密测试')
text = "meet me after the party."
s = 3
encrypt(text, s)print('解密测试(上方加密测试的结果)')
ciphertext = "phhw ph diwhu wkh sduwb"
decrypt(ciphertext)
print("\n")print('加密测试')
text = "This is a test message."
s = 8
encrypt(text, s)print('解密测试(上方加密测试的结果)')
ciphertext = "Bpqa qa i bmab umaaiom."
decrypt(ciphertext)

四、运行结果

image.png
image182c02edab71823c.png


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

相关文章

凯撒密码(移位密码)

凯撒密码&#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;就是 低字节存 放在内存的 低地址端&…

大端和小端的区别和判断

1.概念 大端模式(big endian)&#xff1a;数据的高位字节保存在内存的低地址中&#xff0c;而低位字节保存在内存的高地址中。 小端模式(little endian)&#xff1a;数据的高位字节保存在内存的高地址中&#xff0c;而低位字节保存在内存的低地址中。 问&#xff1a;什么是高…