NOIP201205Vigenère密码

【问题描述】 
  16 世纪法国外交家Blaise de Vigenère设计了一种多表密码加密算法——Vigenère密码。Vigenère 密码的加密解密算法简单易用,且破译难度比较高,曾在美国南北战争中为
南军所广泛使用。 
  在密码学中,我们称需要加密的信息为明文,用 M 表示;称加密后的信息为密文,用C 表示;而密钥是一种参数, 是将明文转换为密文或将密文转换为明文的算法中输入的数据,记为k。 在Vigenère密码中, 密钥k是一个字母串, k=k1k2…kn。当明文M=m1m2…mn时,得到的密文C=c1c2…cn,其中ci=mi®ki,运算®的规则如下表所示: 
 
  Vigenère加密在操作时需要注意: 
1.  ®运算忽略参与运算的字母的大小写,并保持字母在明文 M中的大小写形式; 
2.  当明文M的长度大于密钥k的长度时,将密钥k 重复使用。 
例如,明文M=Helloworld,密钥k=abc 时,密文C=Hfnlpyosnd。 
明文  H  e  l  l  o  w  o  r  l  d 
密钥  a  b  c  a  b  c  a  b  c  a 
密文  H  f  n  l  p  y  o  s  n  d 
 
【输入】 
输入文件名为vigenere.in。 
输入共2行。 
第一行为一个字符串,表示密钥k,长度不超过100,其中仅包含大小写字母。第二行
为一个字符串,表示经加密后的密文,长度不超过1000,其中仅包含大小写字母。 
 
【输出】 
输出文件名为vigenere.out。 
输出共1行,一个字符串,表示输入密钥和密文所对应的明文。 
 
【输入输出样例】

vigenere.in vigenere.out
CompleteVictory
Yvqgpxaimmklongnzfwpvxmniytm
Wherethereisawillthereisaway

【数据说明】 
对于 100%的数据,输入的密钥的长度不超过 100,输入的密文的长度不超过 1000,且都仅包含英文字母。

 #include<iostream>
#include<cstring>
using namespace std;
int main()
{
int w[],i,lk,lh;
char k[],h[],ans[];
cin>>k>>h;
lk=strlen(k);
lh=strlen(h);
for(i=;i<lk;i++)
{
if(k[i]>='a')w[i]=k[i]-'a';
else w[i]=k[i]-'A';
}
i=;
while(i<lh)
{
ans[i]=h[i]-w[i%lk];
if((ans[i]<'A')||(ans[i]<'a'&&h[i]>='a'))ans[i]=ans[i]+;
cout<<ans[i];
i++;
}
}

最新文章

  1. [转载]El Capitan 中 SIP 介绍
  2. Oracle 释放flash recovery area的四种方法
  3. C++数组小知识
  4. Go Go
  5. iOS 加载动态库报错问题
  6. Spring Boot:Consider defining a bean of type &#39;*.*.*&#39; in your configuration解决方案
  7. ntopng网络流量实时监控
  8. Python练习五
  9. git 之连接tfs的git服务器
  10. 【Zookeeper系列】Zookeeper命令操作(转)
  11. 关于servlet转发和重新定向
  12. 自己写的SeekBarPreference,可以实现seekbar滑动监听和设置默认进度和最大进度
  13. HTML提交方式post和get区别(实验)
  14. shell 11函数
  15. Js语言的奇怪特性
  16. 在kolla中配置cinder ceph多后端
  17. 网络网关TCP/IP
  18. 问题 H: 抽奖活动(大数)
  19. FCKeditor文本编辑器的使用方法
  20. 硬件PCB Layout布局布线Checklist检查表(通用版)

热门文章

  1. asp.net MVC中如何用Membership类和自定义的数据库进行登录验证
  2. asp.net批量删除XML节点失败的原因及解决办法
  3. JavaScript实现进入某一页面时自动将鼠标光标放在某一textbox上
  4. Chrome控制台调试工具用法
  5. loadView在App启动时到底都干了些什么?
  6. C# MySqlHelper
  7. mysql 常见的几个错误问题
  8. M面经Prepare: Find integer Average of 2 integers.
  9. SQL 启动服务方法
  10. 最大权闭合图最大获益(把边抽象为点)HDU3879