栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

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

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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数组直接最后是有的,然后一把梭代码

#include 
#include 
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]=='') j=0;
//		cout< 

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

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

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

goowiiiekgmjgoengjrkgnslgjnergnlgnkrljgnls
efwrefwfeiirorrrrrrrrrrrroooooooooooovvvvvvvvvvkslskKKUUHnffffffffsdfaepf

多输出了奇怪的东西。

然后想到可能是新开的char数组没插入,导致直接cout会有问题。

加上后提交就对了

#include 
#include 
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]=='') j=0;
//		cout< 

当然还是建议用strlen获得长度后遍历,看起来更舒服。

这题直接在原数组移位就行,也更省空间,不知道写的时候咋想的直接开个新数组,,,

int l=strlen(m)
for(int i=0;i 

如果新开char数组并且直接输出的话,千万注意补上最后的。

太久不用char数组导致浪费许多时间…

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/352502.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号