C语言实现移位密码

article/2025/10/11 2:28:42

一.认识密码学

加密算法分为对称加密和非对称加密:

  1. 对称加密:对称加密算法使用相同的密钥进行加密和解密操作。发送方和接收方需要共享同一个密钥,这个密钥被称为对称密钥。对称加密算法的优势在于加密和解密速度快,适用于大量数据的加密。然而,对称加密的缺点是密钥分发问题。当通信双方需要建立安全通信时,他们需要以安全的方式共享密钥,否则第三方可能会截获密钥并破解加密的数据。常见的对称加密算法有:AES(Advanced Encryption Standard)、DES(Data Encryption Standard)、3DES(Triple DES)和Blowfish等。

  2. 非对称加密:非对称加密算法使用一对密钥,即公钥和私钥。公钥是公开的,可以被任何人获取;私钥则需要严格保密。使用公钥加密的数据只能用对应的私钥解密,反之亦然。非对称加密解决了对称加密中的密钥分发问题,因为公钥可以公开,不需要安全地传输。然而,非对称加密算法的缺点是加密和解密速度较慢,不适合对大量数据进行加密。常见的非对称加密算法有:RSA、ECC(Elliptic Curve Cryptography)、ElGamal和DSA(Digital Signature Algorithm)等。

在实际应用中,通常会将对称加密和非对称加密结合使用。例如,使用非对称加密算法安全地传输对称密钥,然后使用对称加密算法对数据进行加密。这样既保证了密钥的安全传输,又能高效地加密和解密数据。

二.移位密码

   移位密码(Caesar Cipher)也叫凯撒密码是一种简单的加密技术,它通过将明文中的每个字母按照指定的位数进行移位,从而生成密文。例如,在一个"左移3位"的移位密码中,文中的每个字母都向左移动3个位置,即A变成D,B变成E, 以此类推。移位密码可以被轻松破解,因此现在已经很少用于实际的加密通信中。

三.移位密码原理

2.1 名词解释

  • 明文:发送发想要发送的信息;
  • 密文:经过加密后的信息;
  • 密匙:加密时移动的位数k。
    (这里解释是我个人理解,非标准定义)

2.2 移位加密

具体来说,移位加密通常将明文中的每个字母替换为其在字母表中向后(或向前)移动固定数量的位置得到对应的密文字母。
步骤如下:

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

例如:这里假设明文是 word ,现在的密匙(偏移量)为3,那么我们加密后的密文就是 zrug 。(这里需要结合字母顺序表查看,顺序表由发送发与接收方约定定义,无第三方知道) 这里的偏移量表示字母移动的距离,当偏移量为正数时,字母向后移动;当偏移量为负数时,字母向前移动。

2.3 移位解密

具体来说,移位解密通常将密文中的每个字母替换为其在字母表中向后(或向前)移动固定数量的位置得到对应的明文字母。
步骤如下

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

例如:如果现在的密文是 zrug ,密匙为3,那么明文就是 word

2.4 补充描述

  • 现实生活中,密码是不存在空格的,因为英文大家都知道,传输一篇文章空格要占许多,对发送加密造成干扰,所以约定去掉字母。
  • 补充本次实验所需的字母顺序表
abcdefghijklmnopqrstuvwxyz
012345678910111213141516171819202122232425

这里我们为了方便理解,就用小写。

四.优缺点

优点:

  • 简单易懂
  • 易于实现和使用

缺点:

  • 安全性较低,容易受到暴力破解攻击
  • 容易受到频率分析攻击

缺陷原因分析:

  • 只是将明文中的字符按照一定规则进行移动,不涉及其他复杂的操作;
  • 没有对明文中不同字符出现的频率进行混淆处理。

五.C语言实现

#include <stdio.h>
#include <stdlib.h>
#include <string.h>#define Maxsize 50            //定义信息最大量//加密函数
void jiami(char *&p,int n,int h)
{printf("密文:");for(int i=0;i<h-1;i++)               //循环输出数组的每一个字符{printf("%c",(char) ((p[i] + 'a' - 97) + n - 97) % 26 + 97);}printf("\n");
}//解密函数
void jiemi(char *&p)
{for (int i = 1; i < 26; i++) {printf("k为%d的明文:", i);            //循环输出数组的每一个字符for (int j = 0; j < strlen(p); j++) {printf("%c", (char) (((p[j] + 'a' - 97) + 26 - i - 97) % 26 + 97));//对应ASCLL码表,但是我们自定义了字母顺序表,需要转换范围}printf("\n");}
}int main()
{ char str1[Maxsize],str2[Maxsize];char *p=str1,*q=str2;int n;printf("请输入明文:");            //加密测试fgets(str1, Maxsize, stdin);int len1=strlen(str1);printf("请输入移位密匙:");scanf("%d",&n);jiami(p,n,len1);printf("------------------");printf("\n");printf("请输入密文:");             //解密测试printf("\n");scanf("%s",str2);jiemi(q);}

六.运行结果

if4C.jpg

这是密码学中最简单的一种加密方法,但我们可以使其变得更复杂一些,比如自定义字母顺序表,密匙加强等。同时可以作为我们接触密码学的一个切入点,后面更多复杂的知识点会慢慢接触。


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

相关文章

C语言实现移位密码体制

问题描述&#xff1a;输入密钥K的值&#xff0c;加密算法&#xff1a;e(x)xk(mod 26)。即当前明文字母顺序&#xff08;如A为1&#xff09;加上K值之后对应的字母即为密文。解密算法&#xff1a;d(y)y-k(mod 26)。与加密相反&#xff0c;解密是当前密文字母顺序减去K值对应的字…

c语言中的移位运算符

移位运算符在程序设计中&#xff0c;是位操作运算符的一种。移位运算符可以在二进制的基础上对数字进行平移。 c语言中提供了两种移位运算符&#xff1a; 左移运算符&#xff1a;<< 右移运算符&#xff1a;>> 左移运算符&#xff08;<<&#xff09; int ma…

C语言移位操作、联合体总结

&#xff08;1&#xff09;用|置1&#xff0c;例如P1_flag | 0x01;//置1 0000 0001&#xff0c;把bit0置1&#xff1b; &#xff08;2&#xff09;用&置0&#xff0c;例如P1_flag & 0xFE;//置0 1111 1110&#xff0c;把bit0置0&#xff1b; &#xff08;3&#xff09;把…

C语言——移位操作符

目录 左移操作符 右移操作符 算术右移 逻辑右移 总结 内存中存储的是二进制的补码。 所以移位操作符是对二进制补码进行移位。 先以左移操作符为例:<< 左移操作符 正数的情况&#xff1a; #include<stdio.h> int main() {int a10; //00000000000000000000…

【C语言】超详细的移位、位操作符详解(含力扣实战)

目录 ?1、整数的二进制表示 ?2、移位操作符 ?2.1左移操作符(低位补0) ?举例 ?原理分析 ??2.2右移操作符 ?算术右移(高位补原符号位) ?逻辑右移(高位补0) ??3、位操作符 ?3.1按位与& ?原理分析 ?3.2按位或| ?原理分析 ?3.3按位异或^ ?…

C语言的移位操作

1. C语言的移位 在C语言中&#xff0c;左移为逻辑移位&#xff0c;即左移右侧补0&#xff1b;右移为算术移位&#xff0c;即右移左侧补符号位。 上述程序对 -2 进行左移一位和右移一位的操作&#xff0c;可见-2在内存中存储为ffffffffe即11111111 11111111 11111111 1111 11…

【C语言初阶】操作符之 位运算符详解(“ << ”,“ >> ”,“ ”,“ | ”,“ ^ ”,“ ~ ”)

目录 C语言中六种位运算符&#xff1a; 一、位移运算符 1、移位运算符简介 2、先要了解一点 3、 << 左移运算符 4、>>右移运算符 5、警告 二、 1、& 按位与 2、| 按位或 3、^ 按位异或 4、~ 取反 4、例子 C语言中六种位运算符&#xff1a; &…

C语言中的移位运算

左移运算&#xff1a;对于一个位表示为的操作数 x&#xff0c;x << k 会生成一个指&#xff0c;其位表达式为。也就是说将x右边的w-k位向左移动k位&#xff0c;丢弃最高的k位&#xff0c;并在右端补k个0. 例如&#xff1a;操作数 x 位表达式为 01010101&#xff0c;x &l…

2021 华为秋招笔试题

练习: 题目描述&#xff1a; 学校有一个在线学习系统&#xff0c;没门课程由N个页面组成&#xff08;0< N< 10000&#xff09;个页面组成&#xff0c;学生从第一页开始按顺序学到最后一页提交学习记录。 系统会记录每页停留的时间&#xff08;单位秒&#xff09;&#xf…

详解2021华为笔试三道编程题

目录 2021华为笔试第一道 缓存转发数据包统计&#xff08;100%&#xff09; 解题思路&#xff1a; 参考代码&#xff1a; 2021华为笔试第二题 查找知识图谱中的实例知识&#xff08;100%&#xff09; 解题思路&#xff1a; 参考代码&#xff1a; 2021华为笔试第三题 …

笔试题(2021.7.21华为)

2021.7.21 今晚华为的面试题&#xff0c;帮同学做的&#xff0c;记录一下 说实话还挺难的&#xff0c;基本都算中等题&#xff0c;而且光看题就得看半天 链路可靠性 思路 建图&#xff0c;dfs 我这里是用的哈希表&#xff0c;加数组的形式&#xff0c;也差不多 import java.…

华为笔试AC的两道(第三道不会,我太菜)

1、猪场防疫 老李在多年前承包了一个养猪场&#xff0c; 并引入了若干只种猪&#xff0c;经过这些年的经营&#xff0c;现在养猪场有N只猪&#xff0c;编号从0到N-1 (每只猪无论生死都有唯一的编号) ; 老李在每只猪生产的时候记下了生产的母猪和出生的小猪&#xff0c;格式: x …

2021-07-08 华为2022批笔试

华为2022批笔试 三道题T1T2T3 三道题 总结&#xff1a;写的时候太紧张了&#xff0c;很烦 T1 题目&#xff1a;给出n个任务的最晚完成时间&#xff08;单位为小时&#xff09;和对应积分&#xff0c;每小时只能做一个任务&#xff0c;且超时后不获得积分&#xff0c;求出最大…

2017华为笔试、面试经历

**背景介绍**&#xff1a;2016年7月参加第十一届“华为杯”研究所电子设计大赛获西北赛区一等奖&#xff0c;于2016年8月到上海嘉定工业区参加全国总决赛获全国三等奖。 期间&#xff0c;参加了在线测评、笔试、专业面试、综合面试、部门选择、未完待续。 **备注**&#xff1a;…

4.15日华为笔试

参考&#xff1a; 华为笔试&#xff0c;大家做的怎么样&#xff1f;华为4.15笔试前两题AC - 正则表达式华为笔试2.7 4-15 - C华为4.15笔试 - C 题目简介&#xff1a; 第一题&#xff1a;求获胜者&#xff0c;如果票数相当&#xff0c;按照字母排序&#xff0c;a>b>c,A…

19.华为笔试题整理

1.两数之和 数组可以有重复元素,所以与力扣的第一题稍微有点不同 public int[] twoSum(int[] numbers, int target) {int n numbers.length;HashMap<Integer, Integer> map new HashMap<>();for (int i 0; i < n; i) {int realTarget target - numbers[i];i…

华为2020校招笔试编程题

华为2020校招笔试编程题 刚做完华为的笔试题&#xff0c;简要描述一下三道编程题的解决方法以及python代码实现 第一题大致描述&#xff1a; 给定两个已经升序排序好的的序列A{a1,a2,a3,...an} 和B{b1,b2,b3...bn} &#xff0c;一个数R&#xff0c;找出满足以下条件的的&#x…

华为笔试题 2022.3.30

1、业务部署芯片 思路&#xff0c;就硬模拟 #include <algorithm> #include <iostream> #include <string> #include <vector>using namespace std;int main() {int m, n;cin >> m;cin >> n;char arr[n];for (int i 0; i < n; i) {ci…

华为2019届校招笔试题

1. 给出一个字符串&#xff0c;将重复的字符去除&#xff0c;仅保留第一次出现的字符&#xff0c;且保持去重后的字符在原字符串中的顺序不变。 输入数据是一个字符串&#xff08;不包含空格&#xff09; 输出去重后的字符串 输入&#xff1a;12ere2 输出&#xff1a;12er…

【JAVA】【华为校园招聘笔试-软件】2020-09-09

前言 华为三道题&#xff0c;100200300&#xff0c;100及格&#xff0c;大家做对第一题就好了&#xff0c;祝大家全都有心仪的offer&#xff0c;不要慌&#xff0c;不要焦虑 一、完美排列——玩具&#xff08;全A&#xff09;&#xff08;注意&#xff1a;题目中说&#xff…