凯撒密码Caesar
//@132屋里上课群
#include<stdio.h>
#include<stdlib.h>//颜色
using namespace std;
int jiami();
int jiemi();
int main()
{
printf("************************************************************\n");
printf("* 凯撒Caesar *\n");
printf("* *\n");
printf("* 1.加密 *\n");
printf("* 2.解密 *\n");
printf("* 【注】:退出请按0 *\n");
printf("************************************************************\n");
system("color 40");
int id;
printf("【键入操作代号】:");
scanf("%d",&id);
switch(id)
{
case 1:
jiami();
break;
case 2:
jiemi();
break;
case 0:
system("color 40");
return 0;
default:
main ();
}
return 0;
}
/***********加密*************/
int jiami()
{
int ii=1,kk=2;
printf("[键入完成请输入'/'] \n\n");
printf("———————————————————————————————————————————————————\n");
printf("[明文信息]\n\n");
char miw[150];
char mingw[100];
for(ii;ii<100;ii++)
{
mingw[ii]=getchar();
if(mingw[ii]<=120&&mingw[ii]>=97)
{
miw[ii]=mingw[ii]+3;
continue;
}
if(mingw[ii]=='x')
{
miw[ii]='a';
}
if(mingw[ii]=='y')
{
miw[ii]='b';
}
if(mingw[ii]=='z')
{
miw[ii]='c';
}
if(mingw[ii]==' ')
{
miw[ii]=' ';
}
if(mingw[ii]=='/')
{
printf("\n\n");
printf("[密文信息] \n\n");
system("color 50");
break;
}
}
for(kk;kk<ii;kk++)
{
if(miw[kk]==' ')
{
printf(" ");
continue;
}
printf("%c",miw[kk]);
}
printf("\n\n");
int id;
printf("———————————————————————————————————————————————————\n");
printf("【键入操作代号】:");
scanf("%d",&id);
switch(id)
{
case 1:
jiami();
break;
case 2:
jiemi();
break;
default:
main ();
case 0:
system("color 40");
return 0;
}
return 0;
}
/***********解密*************/
int jiemi()
{
int ii=1,kk=1;
printf("[键入完成请输入'/'] \n\n");
printf("———————————————————————————————————————————————————\n");
printf("[密文信息]\n\n");
char miw[150];
char mingw[100];
for(ii;ii<100;ii++)
{
miw[ii]=getchar();
if(miw[ii]<=123&&miw[ii]>=100)
{
mingw[ii]=miw[ii]-3;
continue;
}
if(miw[ii]=='a')
{
mingw[ii]='x';
}
if(miw[ii]=='b')
{
mingw[ii]='y';
}
if(miw[ii]=='c')
{
mingw[ii]='z';
}
if(miw[ii]==' ')
{
mingw[ii]=' ';
}
if(miw[ii]=='/')
{
printf("\n\n");
printf("[明文信息] \n\n");
system("color 60");
break;
}
}
for(kk;kk<ii;kk++)
{
if(mingw[kk]==' ')
{
printf(" ");
continue;
}
printf("%c",mingw[kk]);
}
printf("\n\n");
int id;
printf("———————————————————————————————————————————————————\n");
printf("【键入操作代号】:");
scanf("%d",&id);
switch(id)
{
case 1:
jiami();
break;
case 2:
jiemi();
break;
case 0:
system("color 40");
return 0;
default:
main ();
}
return 0;
}
@信息安全概论作业


凯撒密码Caesar的更多相关文章
- FCC JS基础算法题(13):Caesars Cipher(凯撒密码)
题目描述: 下面我们来介绍风靡全球的凯撒密码Caesar cipher,又叫移位密码.移位密码也就是密码中的字母会按照指定的数量来做移位.一个常见的案例就是ROT13密码,字母会移位13个位置.由'A ...
- 凯撒密码(Caesar cipher) 详解
------------恢复内容开始------------ 最近训练CTF的时候,发现密码学这块的知识不太系统,所以自己接下来会陆陆续续整理出来 就先从古典密码中的凯撒密码说起吧 凯撒密码内容比较简 ...
- Python用户名密码登录系统(MD5加密并存入文件,三次输入错误将被锁定)及对字符串进行凯撒密码加解密操作
# -*- coding: gb2312 -*- #用户名密码登录系统(MD5加密并存入文件)及对字符串进行凯撒密码加解密操作 #作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.co ...
- C语言:凯撒密码的实现
凯撒密码的实现(10分)题目内容: 凯撒密码(caeser)是罗马扩张时期朱利斯?凯撒(Julius Caesar)创造的,用于加密通过信使传递的作战命令.它将字母表中的字母移动一定位置而实现加密. ...
- 凯撒密码 CH Round #57 - Story of the OI Class
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2357%20-%20Story%20of%20the%20OI%20Class/凯撒密码 题解:刚开始想map, ...
- java:凯撒密码及String的应用
一,凯撒密码 古罗马皇帝凯撒在打仗时曾使用过以下方法加密军事情报 现在用java实现 程序设计思想: 1,字符串首先要转化为字符数组,才能依次加密 2,当原来的字符为X,Y,Z时,加密后要转化为A,B ...
- 凯撒密码加密解密--JAVA实现(基础)
凯撒密码一种代换密码,据说凯撒是率先使用加密函的古代将领之一,因此这种加密方法被称为恺撒密码.凯撒密码的基本思想是:通过把字母移动一定的位数来实现加密和解密.明文中的所有字母都在字母表上向后(或向前) ...
- Python的一个解释凯撒密码的程序
#!/usr/bin/env python # -*- coding: utf-8 -*- ''' { Title:CaserCode Author:naiquan Type:crypto Detai ...
- 凯撒密码移位python
#!/usr/bin/python'''凯撒密码'''a="gmbhqwertghjkcvbzn"s=[""]*len(a)for j in range(26) ...
随机推荐
- C#修改AD账号及密码
在使用AD域环境搭建的账号系统修改密码的时候比较麻烦一般需要管理员在域环境去进行对用户的密码进行修改. 以下就是用来查询和修改AD域密码的方法. 1 /// <summary> 2 /// ...
- BUAAOO第二单元代码分析
第一次作业 设计思路与感想 第一次作业是要求有捎带的电梯实现, 第一次作业是花费的时间比较长的一次,花费了很多的时间去思考架构的问题.起初是想要搞三个线程的:输入线程,调度器线程和电梯线程,想要搞一个 ...
- 原创 Spring Boot 2.3 新特性分层JAR
背景 在我们实际生产容器化部署过程中,往往会遇到 Docker 镜像很大,部署发布很慢的情况 影响 docker 镜像大小的因素,主要有以下三个方面: 基础镜像的大小 .尽量选择 aphine 作为基 ...
- Window、Ubuntu传输文件到阿里云服务器
Ubuntu传输文件到阿里云服务器 scp -r file(ubuntu的文件) root(用户名)@xx.xx.xx.xx(公网ip):/home/(目标文件夹) Window传输文件到阿里云服务器 ...
- Idea使用指南--实用版
idea使用指南--基础配置: 视频链接:https://www.bilibili.com/video/av21735428/?p=1 idea安装: 快捷方式create destop shortc ...
- kubernets-java 动态修改deployment 的replicas
/** * Scale up/down the number of pod in Deployment * * @param deploymentName * @param numberOfRepli ...
- JavaScript实现斐波那契数列
什么是斐波那契数列 斐波那契数列(Fibonacci sequence),又称黄金分割数列.因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为&qu ...
- 基于 Socket 的群聊聊天室(带图形界面,包含注册、登录、数据入库功能)
代码下载 https://github.com/juno3550/GroupChatRoom 实现框架 Chat 包: server.py:服务器端执行代码(TCP 服务器,根据客户端消息调用 mod ...
- H5小技巧之——巧用<a>标签锚链接(#锚点链接 #页面特定位置 #DOM定位 #hash路由中使用锚链接)
#作者:矩阵鱼--代码中游泳的咸鱼 前端开发中,常遇到定位到页面某特定位置的需求,JavaScript提供的el.scrollIntoView() 和 el.scrollIntoViewIfNeede ...
- 数据分析处理之PCA OLSR PCR PLSR(NIPALS)及其Matlab代码实现
传统的OLS(普通最小二乘)方法无法解决样本数据的共线性(multicollinearity)问题,如果你的数据样本中每个特征变量具有共线性,那么使用基于PCA的PCR和PLSR方法对数据样本进行回归 ...