洛谷 B4500:[GESP202603 三级] 凯撒密码 ← 字符串
【题目来源】https://www.luogu.com.cn/problem/B4500【题目描述】凯撒密码是一种替换加密技术明文中的所有字母都在字母表上向后或向前按照一个固定数目进行偏移后被替换成密文。例如当偏移量是 3 的时候所有的字母 A 将被替换成 DB 被替换成 EC 被替换成 F以此类推W 被替换成 ZX 被替换成 AY 被替换成 BZ 被替换成 C。这个加密方法是以罗马共和时期凯撒的名字命名的据称当年凯撒曾用此方法与其将军们进行联系。但是和所有的利用字母表进行替换的加密技术一样凯撒密码非常容易被破解而且在实际应用中也无法保证通信安全。现在给你一个已破解的凯撒密码明文与密文与一个有相同偏移量的未破解凯撒密码密文请你帮忙破解它。【输入格式】输入共三行第一行包含一个字符串表示已破解的凯撒密码明文第二行包含一个字符串表示已破解的凯撒密码密文第三行包含一个字符串表示待破解的凯撒密码密文。【输出格式】输出一行包含一个字符串表示待破解的凯撒密码对应的明文。【输入样例】ABCDEFGVWXYZDEFGHIJYZABCWKHTXLFNEURZQIRAMXPSVRYHUWKHODCBGRJ【输出样例】THEQUICKBROWNFOXJUMPOVERTHELAZYDOG【数据范围】保证密码长度均不超过 1000所有字符串由大写字母组成。【算法分析】●明文(密文-d26) mod 26其中 d 是统一偏移量。【算法代码】#include bits/stdc.h using namespace std; int main() { string cipher,plain,s; cincipherplains; int offset(plain[0]-cipher[0]26)%26; for(int i0; is.size(); i) { int t(s[i]-A-offset26)%26; coutchar(At); } coutendl; return 0; } /* in: ABCDEFGVWXYZ DEFGHIJYZABC WKHTXLFNEURZQIRAMXPSVRYHUWKHODCBGRJ out: THEQUICKBROWNFOXJUMPOVERTHELAZYDOG */【参考文献】https://mp.weixin.qq.com/s/IfBFHKAtG7om7kmVoBckBg
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2419457.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!