当前位置: 首页 > news >正文

洛谷 B4500:[GESP202603 三级] 凯撒密码 ← 字符串

【题目来源】
https://www.luogu.com.cn/problem/B4500

【题目描述】
凯撒密码是一种替换加密技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是 3 的时候,所有的字母 A 将被替换成 D,B 被替换成 E,C 被替换成 F,以此类推,W 被替换成 Z,X 被替换成 A,Y 被替换成 B,Z 被替换成 C。这个加密方法是以罗马共和时期凯撒的名字命名的,据称当年凯撒曾用此方法与其将军们进行联系。
但是和所有的利用字母表进行替换的加密技术一样,凯撒密码非常容易被破解,而且在实际应用中也无法保证通信安全。
现在给你一个已破解的凯撒密码明文与密文,与一个有相同偏移量的未破解凯撒密码密文,请你帮忙破解它。

【输入格式】
输入共三行:
第一行包含一个字符串,表示已破解的凯撒密码明文;
第二行包含一个字符串,表示已破解的凯撒密码密文;
第三行包含一个字符串,表示待破解的凯撒密码密文。

【输出格式】
输出一行,包含一个字符串,表示待破解的凯撒密码对应的明文。

【输入样例】
ABCDEFGVWXYZ
DEFGHIJYZABC
WKHTXLFNEURZQIRAMXPSVRYHUWKHODCBGRJ​​​​​​​

【输出样例】
THEQUICKBROWNFOXJUMPOVERTHELAZYDOG​​​​​​​

【数据范围】
保证密码长度均不超过 1000,所有字符串由大写字母组成。

【算法分析】
● 明文=(密文-d+26) mod 26​​​​​​​,其中 d 是统一偏移量。

【算法代码】

#include <bits/stdc++.h>
using namespace std;int main() {string cipher,plain,s;cin>>cipher>>plain>>s;int offset=(plain[0]-cipher[0]+26)%26;for(int i=0; i<s.size(); i++) {int t=(s[i]-'A'-offset+26)%26;cout<<char('A'+t);}cout<<endl;return 0;
}/*
in:
ABCDEFGVWXYZ
DEFGHIJYZABC
WKHTXLFNEURZQIRAMXPSVRYHUWKHODCBGRJout:
THEQUICKBROWNFOXJUMPOVERTHELAZYDOG
*/





【参考文献】
https://mp.weixin.qq.com/s/IfBFHKAtG7om7kmVoBckBg


 

http://www.jsqmd.com/news/482431/

相关文章:

  • 【原】Python+AI学习笔记(01)大模型调用准备工作 与 OpenAI库基础使用
  • Omsk Metro的题解
  • 东华OJ-进阶题-10-分解质因数(C++)
  • 设计模式2-结构性
  • 一行命令搞定驱动安装!MicroPython 开发有了自己的 “PyPI”包管理平台!
  • Problems(2026/02 ~ 2026/03)
  • React15 - redux中combineReducer的作用
  • 图像拼接对齐
  • Problems(2026/01 ~ 2026/03)
  • 音乐会节目单
  • 「NOI2005」聪聪和可可 的 题解
  • 三角函数 - 重制版
  • Problems(2025 年及更早)
  • 编程对拍助手 autohack-next
  • 如何优化大数据领域的数据建模流程
  • MinIO 分布式高可用部署
  • 征程 6P codec decoder sample
  • UV 下载与安装指南
  • Linux全网备份项目与NFS存储服务实战全攻略
  • 16 Nginx服务的信号控制
  • Linux Rsync备份服务实战全攻略
  • AI Coding 从“抽盲盒”到“开火箭”:SDD+TDD 开发模式实战揭秘
  • Problems(大纲)
  • React15 - React Redux组件模式性能对比
  • 3月15日(进阶6)
  • AI 不会先杀死 SaaS,但会先杀死 SaaS 的旧玩法
  • 最强生图模型NanoBanana 2,一手深度测- 附教程
  • Agentic LLM工作流在钻井日报分析中的应用
  • C# switch case 的极限教程
  • Kali Linux渗透测试与网络攻防实验靶场