c&c++中char的一个注意事项

起因是今天做算法实验中的一道题

问题 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 加密在操作时需要注意:

  1. ® 运算忽略参与运算的字母的大小写,并保持字母在明文 MM 中的大小写形式;
  2. 当明文 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;
}

image-20211028190452820

没问题直接交了,然后答案错误。。。

一看逻辑没啥错,这有点搞人了。。。

然后随便输字符,试了很多都是正确结果,心态大崩,直到试出了个奇怪的玩意

goowiiiekgmjgoengjrkgnslgjnergnlgnkrljgnls
efwrefwfeiirorrrrrrrrrrrroooooooooooovvvvvvvvvvkslskKKUUHnffffffffsdfaepf

image-20211028190744602

多输出了奇怪的东西。

然后想到可能是新开的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数组导致浪费许多时间…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值