凯撒密码

在密码学中,恺撒密码(英语:Caesar cipher),或称恺撒加密恺撒变换变换加密,是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。这个加密方法是以罗马共和时期恺撒的名字命名的,当年恺撒曾用此方法与其将军们进行联系。                                                         ——来自百度百科

代码实现

#include<iostream>

#include<cmath>

#define N 70

using namespace std;

void encryption(char* arr, int k)        //将数组指针和偏移量传入encryption函数

{

for (int i = 0; i < N; i++)        //利用for循环对字符串的每个字母做加密操作

{

if (arr[i] >= 'A' && arr[i] <= 'Z')        //分支I-若字母是A到Z之间的

{

arr[i] = (arr[i] - 'A' + k) % 26 + 'A';

//计算字符数组第i个元素到A的距离(arr[i] - 'A')

//对距离(arr[i] - 'A')进行偏移(k),

//若ASK码值超过了字母表范围,取模运算(%26)将把ASK码值拽回字母表范围

//将以上结果加上A对应的ASK码(+'A'),即把经过加密的ASK码垒到'A'的ASK码值上

//将上述储存到字符数组对应的位置(arr1[i])上

}

else if (arr[i] >= 'a' && arr[i] <= 'z')        //分支II-若字母是a到z之间的

{

arr[i] = (arr[i] - 'a' + k) % 26 + 'a';

//将分支I的大写字母字符'A'与'Z'改成小写字母字符'a'与'z'即可

}

}

}

int main()

{

int k = 4;        //k为加密字符串的右移量

char arr1[N] = { "Beijing" };        //arr1是要加密的字符串

cout << "请输入要加密的字符串(若输入空格,请用-(减号)代替)" << endl;

cin >> arr1;

cout << "请输入偏移量(右移)" << endl;

cin >> k;

cout << endl;

cout << "要加密的字符串是" << endl << arr1 << endl;

cout << "字符串偏移量是" << k << endl;

cout << endl;

encryption(arr1, k);

cout << "加密后的字符串为" << endl << arr1 << endl;

return 0;

}

潜在问题

以原字符串"Beijing-Information-Science-and-Technology-University" ,偏移量为 4

加密结果    "Fimnmrk-Mrjsvqexmsr-Wgmirgi-erh-Xiglrspskc "    为例

若想实现密文到明文的转换

输入偏移量 -4

解密结果 Beijing-Information-Science-and-Technolog_-Universit_

解密时部分字母会出现错误

【C++】凯撒密码 实现加密与解密相关推荐

  1. python编写凯撒密码的加密函数_python实现 古典密码 凯撒密码的加密与解密

    python实现 古典密码 凯撒密码的加密与解密 实现效果如下图: # 凯撒密码加密与解密 # author Sundm string = ['a','b','c','d','e','f','g',' ...

  2. 凯撒密码c++语言程序,凯撒密码(加密与解密)

    下面是编程之家 jb51.cc 通过网络收集整理的代码片段. 编程之家小编现在分享给大家,也给大家做个参考. /******************************************** ...

  3. 凯撒密码(加密与解密)

    /************************************************************************/ /*caeser.c /* 凯撒密码是把明文字符按 ...

  4. Python实现凯撒密码的加密与解密

    在密码学中,我们把想要加密的消息叫做明文(plain text).把明文转换成加密后的消息叫做对明文加密(encrypting),明文加密后变成(cipher text). 凯撒密码的密钥是1到26之 ...

  5. 凯撒密码的加密解密算法实现

    用C++实现凯撒密码的加密解密算法 在密码学中,恺撒密码(英语:Caesar cipher),或称恺撒加密.恺撒变换.变换加密,是一种最简单且最广为人知的加密技术. 它是一种替换加密的技术,明文中的所 ...

  6. 凯撒密码的加密,破解,以及暴力破解法

    凯撒密码的加密 #include <stdio.h>int main() { char a[80],b[80];//a为原码,b为加密 int i,k; scanf("%d&qu ...

  7. Java版 凯撒密码 加密、解密、暴力破解

    Java版 凯撒密码 加密.解密.暴力破解 用Java实现凯撒密码的 '加密' 和 '解密' 工作 代码实现如下: 代码片 package com.hellow.demo;import java.ut ...

  8. 运用python编写凯撒密码并实现_凯撒密码实现英文短句的加解密

    1. 将"We are students."这个英文词句用k=4的凯萨密码翻译成密码 1. 恺撒密码, 作为一种最为古老的对称加密体制,他的基本思想是: 通过把字母移动一定的位数来 ...

  9. Python密码学入门:凯撒密码

    1 什么是密码学 自古以来,间谍.士兵.黑客.海盗.商人等人,大多依靠密码学来确保他们的秘密不会人尽皆知.密码学是一门使用秘密编码的学科.想要明白密码长什么样,看一看下面两段文本. nyr N.vNw ...

  10. 古典密码算法(凯撒密码,矩阵换位密码) python实现

    古典密码算法 python实现 通过编程实现替代密码和置换密码算法,在这里通过python实现了对凯撒密码的加密与解密,以及对矩阵换位密码的加密与解密. 凯撒密码的相关算法是O(n)O(n)O(n)的 ...

最新文章

  1. python增删改查的框架_python的Web框架,Django的ORM,模型基础,MySQL连接配置及增删改查...
  2. 看了《为什么你应该写博客》有感
  3. openstack第四章:neutron— 网络服务
  4. STL中empty()函数的误用
  5. 【专栏必读】(计算机组成原理题目题型总结)计理期末考试408统考算机组成原必考题型总结
  6. iframe 去除边框 背景透明等设置 待修改
  7. mysql 命令删库名,MySQL控制台删除数据库命令 drop database 数据库名
  8. 告别复杂WCF扩展 REST过程 ,让他 so easy
  9. Navicat for Mysql 的使用
  10. VS2015:出现devenv.sln解决方案保存对话框
  11. T-SQL笔记8:索引
  12. 笔记本关闭触摸板——解决无法关闭触摸板问题
  13. t分布 u分布 卡方分布_三大抽样分布:卡方分布,t分布和F分布的简单理解
  14. 新版百度地图的覆盖物描述
  15. 机器学习(周志华)学习笔记(一)
  16. 银行外包Java开发的一些感想2023.2.5
  17. 深度解码真实的90后消费:敢爱敢花,却被高负债压得透不过气
  18. Retrofit 使用
  19. hadoop的压缩方式snappy
  20. 剖析支付宝线下支付技术

热门文章

  1. 关于x64dbg里面的Assemble
  2. QML 环形进度条canvas 98行代码实现
  3. Compile LLVM+CLANG 4.0.1 for RHEL6
  4. 进入Vmware虚机的BIOS
  5. LISP 冻结excel窗格_Excel这10个实操技巧,每个都很牛逼,绝对不能错过
  6. 微型计算机在硬件上是由,208可打印本资料微机原理与汇编期末考试试卷A卷答案...
  7. android中的progressbar,Android中ProgressBar用法简单实例
  8. 安卓rom制作教程_Android ROM制作教程-开发必需
  9. 安卓java编译器_最方便的安卓手机端Java编译程序(支持中文字符串)
  10. python编程的区别_Python与其它编程语言的区别