IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> c&c++中char的一个注意事项 -> 正文阅读

[C++知识库]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数组导致浪费许多时间…

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-10-29 12:49:03  更:2021-10-29 12:50:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/1 14:38:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码