起因是今天做算法实验中的一道题
问题 B: Vigenère 密码
时间限制: 1 Sec 内存限制: 128 MB
提交: 733 解决: 500
[提交][状态][讨论版]
题目描述
16 世纪法国外交家 Blaise de Vigenère 设计了一种多表密码加密算法——Vigenère 密码。Vigenère 密码的加密解密算法简单易用,且破译难度比较高,曾在美国南北战争中为南军所广泛使用。
在密码学中,我们称需要加密的信息为明文,用 MM 表示;称加密后的信息为密文,用 CC 表示;而密钥是一种参数,是将明文转换为密文或将密文转换为明文的算法中输入的数据,记为 k。 在 Vigenère 密码中,密钥 k 是一个字母串,k=k1k2…kn。当明文 M = m1m2…mn 时,得到的密文 C = c1c2…cn ,其中 ci = mi ® ki,运算 ® 的规则如下表所示:
Vigenère 加密在操作时需要注意:
- ® 运算忽略参与运算的字母的大小写,并保持字母在明文 MM 中的大小写形式;
- 当明文 MM 的长度大于密钥 kk 的长度时,将密钥 kk 重复使用。 例如,明文 M=M=Helloworld,密钥 k=k=abc时,密文 C=C=Hfnlpyosnd。
输入
第一行为一个字符串,表示密钥 k,长度不超过 100,其中仅包含大小写字母。
第二行为一个字符串,表示经加密后的密文,长度不超过 1000,其中仅包含大小写字母。
输出
输出共 1行,一个字符串,表示输入密钥和密文所对应的明文。
样例输入
CompleteVictory
Yvqgpxaimmklongnzfwpvxmniytm
样例输出
Wherethereisawillthereisaway
这题还是很简单的,直接移位,注意下大小写字母的移动即可(开始还是看错题,以为求的是密文
由于太久没用char,之前都是用string,并且我还开了个结果数组,没在原数组做移位操作,导致踩了坑…
首先忘了char咋遍历了直接搜了下
for(int i=0;m[i];i++)
当然是记得输入char数组直接最后是有\0
的,然后一把梭代码
#include <iostream>
#include <string.h>
using namespace std;
int main()
{
char k[105],m[1005],c[1005];
cin>>k>>m;
int j=0;
for(int i=0;m[i];i++){
if(k[j]>'Z') k[j]-=32;
c[i]=m[i]-(k[j]-'A');
if(m[i]>'Z'){
if(c[i]<'a') c[i]+=26;
}else{
if(c[i]<'A') c[i]+=26;
}
j++;
if(k[j]=='\0') j=0;
// cout<<m[i]<<" "<<k[j]<<" "<<c[i]<<endl;
}
cout<<c;
return 0;
}
没问题直接交了,然后答案错误。。。
一看逻辑没啥错,这有点搞人了。。。
然后随便输字符,试了很多都是正确结果,心态大崩,直到试出了个奇怪的玩意
goowiiiekgmjgoengjrkgnslgjnergnlgnkrljgnls
efwrefwfeiirorrrrrrrrrrrroooooooooooovvvvvvvvvvkslskKKUUHnffffffffsdfaepf
多输出了奇怪的东西。
然后想到可能是新开的char数组没插入\0
,导致直接cout会有问题。
加上后提交就对了
#include <iostream>
#include <string.h>
using namespace std;
int main()
{
char k[105],m[1005],c[1005];
cin>>k>>m;
int j=0;
for(int i=0;m[i];i++){
if(k[j]>'Z') k[j]-=32;
c[i]=m[i]-(k[j]-'A');
if(m[i]>'Z'){
if(c[i]<'a') c[i]+=26;
}else{
if(c[i]<'A') c[i]+=26;
}
j++;
if(k[j]=='\0') j=0;
// cout<<m[i]<<" "<<k[j]<<" "<<c[i]<<endl;
}
int x=strlen(m);
c[x]='\0';
cout<<c;
return 0;
}
当然还是建议用strlen获得长度后遍历,看起来更舒服。
这题直接在原数组移位就行,也更省空间,不知道写的时候咋想的直接开个新数组,,,
int l=strlen(m)
for(int i=0;i<m;i++)
如果新开char数组并且直接输出的话,千万注意补上最后的\0
。
太久不用char数组导致浪费许多时间…