实验报告题目: 采用python或c++语言,实现如下功能: 实现古典密码中的移位密码和仿射密码,具体实现如下接口: python 接口: <<<<<移位密码>>>>> def is_valid_s(k): 判断k是否为合理的密钥 def encrypt_s(p, k): 密钥合理,则采用k对p进行加密,p为明文字符串,k为密钥,返回密文。 密钥不合理,则返回none. def decrypt_s(c,k): 密钥合理,则采用k对c进行解密,c为密文字符串,k为密钥,返回密文。 密钥不合理,则返回none. <<<<<仿射密码>>>>> def is_valid_a(a,b): 判断(a,b)是否为合理的密钥 def encrypt_s(p, a,b): 密钥合理,则采用a,b对p进行加密,p为明文字符串,a,b为密钥,返回密文。 密钥不合理,则返回none. def decrypt_s(c,a,b): //注意解密的时候需要计算a的逆元 密钥合理,则采用a,b对c进行解密,c为密文字符串,k为密钥,返回密文。 密钥不合理,则返回none. c++接口: <<<


以下是用 Python 实现的古典密码中的移位密码和仿射密码的代码: ```python def is_valid_s(k): # 如果密钥 k 是在合理范围内(例如 0 到 25 之间),则认为合理 if 0 <= k <= 25: return True else: return False def encrypt_s(p, k): if is_valid_s(k): result = "" for char in p: if char.isalpha(): if char.islower(): new_char = chr(((ord(char) - ord('a') + k) % 26) + ord('a')) else: new_char = chr(((ord(char) - ord('A') + k) % 26) + ord('A')) result += new_char else: result += char return result else: return None def decrypt_s(c, k): if is_valid_s(k): result = "" for char in c: if char.isalpha(): if char.islower(): new_char = chr(((ord(char) - ord('a') - k + 26) % 26) + ord('a')) else: new_char = chr(((ord(char) - ord('A') - k + 26) % 26) + ord('A')) result += new_char else: result += char return result else: return None def is_valid_a(a, b): # 这里可以添加更复杂的判断逻辑,比如 a 和 b 的取值范围等 if a!= 0 and b!= 0: return True else: return False def encrypt_a(p, a, b): if is_valid_a(a, b): result = "" for char in p: if char.isalpha(): if char.islower(): new_char = chr(((a * (ord(char) - ord('a')) + b) % 26) + ord('a')) else: new_char = chr(((a * (ord(char) - ord('A')) + b) % 26) + ord('A')) result += new_char else: result += char return result else: return None def decrypt_a(c, a, b): if is_valid_a(a, b): # 计算 a 的逆元 inv_a = pow(a, -1, 26) result = "" for char in c: if char.isalpha(): if char.islower(): new_char = chr(((inv_a * ((ord(char) - ord('a')) - b + 26)) % 26) + ord('a')) else: new_char = chr(((inv_a * ((ord(char) - ord('A')) - b + 26)) % 26) + ord('A')) result += new_char else: result += char return result else: return None ``` 对于这段代码,您需要注意以下 3 点逻辑: 1. 对于密钥的有效性判断要准确,确保加密和解密过程中使用的密钥是合法的。 2. 在加密和解密的计算过程中,要注意处理字符的大小写以及边界情况。 3. 计算逆元时要确保计算的准确性,以保证解密能够正确进行。 [2024-12-18 15:55:47 | AI写代码神器 | 798点数解答]
- 实验报告题目: 采用python或c++语言,实现如下功能: 实现古典密码中的移位密码和仿射密码,具体实现如下接口: python 接口: <<<<<移位密码>>>>> def is_valid_s(k): 判断k是否为合理的密钥 def encrypt_s(p, k): 密钥合理,则采用k对p进行加密,p为明文字符串,k为密钥,返回密文。 密钥不合理,则返回none. def decrypt_s(c,k): 密钥合理,则采用k对c进行解密,c为密文字符串,k为密钥,返回密文。 密钥不合理,则返回none. <<<<<仿射密码>>>>> def is_valid_a(a,b): 判断(a,b)是否为合理的密钥 def encrypt_s(p, a,b): 密钥合理,则采用a,b对p进行加密,p为明文字符串,a,b为密钥,返回密文。 密钥不合理,则返回none. def decrypt_s(c,a,b): //注意解密的时候需要计算a的逆元 密钥合理,则采用a,b对c进行解密,c为密文字符串,k为密钥,返回密文。 密钥不合理,则返回none. c++接口: <<<(798点数解答 | 2024-12-18 15:55:47)163
- 采用c++语言,实现如下功能: 实现古典密码中的移位密码和仿射密码,具体实现如下接口: c++接口: <<<<<移位密码>>>>> bool is_valid_s(unsinged char k) { 判断k是否为合理的密钥 } int encrypt_s(unsigned char* p, unsigned char k) { 密钥合法则返回1,且密文覆盖明文: 密钥不合法则返回0. } int decrypt_s(unsigned char* c, unsigned char k) { 密钥合法则返回1,且明文覆盖密文: 密钥不合法则返回0. } <<<<<仿射密码>>>>> bool in_valid_a(unsinged char a, unsigned char b) { 判断a,b是否为合理的密钥 } int encrypt_a(unsigned char* p, unsigned char a, unsigned char b) { 密钥合法则返回1,且密文覆盖明文: 密钥不合法则返回0. } int decrypt_a(unsigned char* c, unsign(812点数解答 | 2024-12-18 16:02:36)251
- 编程实现一个简单的密码设置系统,从键盘输入字符命令,分别实现相应的功能。 初始化设置密码为123456,等待命令输入: (1)输入字符‘1’,功能:密码确认。提示输入密码,密码正确,返回“密码正确”,否则返回密码错误。 (2)输入字符‘2’,功能:设置密码。输入设置密码后,系统提示设置正确。 (3)输入字符‘3’,功能:显示密码。 (4)输入字符‘4’,功能:重置密码。密码重置为6个0; (5)输入字符‘0’,功能:系统退出。 (6)输入其他字符,系统提示输入错误请重新输入。 (286点数解答 | 2025-03-28 10:43:21)226
- 编程实现一个简单的密码设置系统,从键盘输入字符命令,分别实现相应的功能。 初始化设置密码为123456,等待命令输入: (1)输入字符‘1’,功能:密码确认。提示输入密码,密码正确,返回“密码正确”,否则返回密码错误。 (2)输入字符‘2’,功能:设置密码。输入设置密码后,系统提示设置正确。 (3)输入字符‘3’,功能:显示密码。 (4)输入字符‘4’,功能:重置密码。密码重置为6个0; (5)输入字符‘0’,功能:系统退出。 (6)输入其他字符,系统提示输入错误请重新输入。 用c语言 (414点数解答 | 2025-03-28 10:43:55)217
- 程实现一个简单的密码设置系统,从键盘输入字符命令,分别实现相应的功能。 初始化设置密码为123456,等待命令输入: (1)输入字符‘1’,功能:密码确认。提示输入密码,密码正确,返回“密码正确”,否则返回密码错误。 (2)输入字符‘2’,功能:设置密码。输入设置密码后,系统提示设置正确。 (3)输入字符‘3’,功能:显示密码。 (4)输入字符‘4’,功能:重置密码。密码重置为6个0; (5)输入字符‘0’,功能:系统退出。 (6)输入其他字符,系统提示输入错误请重新输入 用c语言 (519点数解答 | 2025-03-28 12:42:02)257
- 初始化设置密码为123456,等待命令输入: (1)输入字符‘1’,功能:密码确认。提示输入密码,密码正确,返回“密码正确”,否则返回密码错误。 (2)输入字符‘2’,功能:设置密码。输入设置密码后,系统提示设置正确。 (3)输入字符‘3’,功能:显示密码。 (4)输入字符‘4’,功能:重置密码。密码重置为6个0; (5)输入字符‘0’,功能:系统退出。 (6)输入其他字符,系统提示输入错误请重新输入。 用c语言(409点数解答 | 2025-04-05 18:09:56)212
- 初始化设置密码为123456,等待命令输入: (1)输入字符‘1’,功能:密码确认。提示输入密码,密码正确,返回“密码正确”,否则返回密码错误。 (2)输入字符‘2’,功能:设置密码。输入设置密码后,系统提示设置正确。 (3)输入字符‘3’,功能:显示密码。 (4)输入字符‘4’,功能:重置密码。密码重置为6个0; (5)输入字符‘0’,功能:系统退出。 (6)输入其他字符,系统提示输入错误请重新输入。 用c语言 (454点数解答 | 2025-04-05 18:48:42)206
- 初始化设置密码为123456,等待命令输入: (1)输入字符‘1’,功能:密码确认。提示输入密码,密码正确,返回“密码正确”,否则返回密码错误。 (2)输入字符‘2’,功能:设置密码。输入设置密码后,系统提示设置正确。 (3)输入字符‘3’,功能:显示密码。 (4)输入字符‘4’,功能:重置密码。密码重置为6个0; (5)输入字符‘0’,功能:系统退出。 (6)输入其他字符,系统提示输入错误请重新输入 C语言 (413点数解答 | 2025-04-06 15:37:16)156
- 初始化设置密码为123456,等待命令输入: (1)输入字符‘1’,功能:密码确认。提示输入密码,密码正确,返回“密码正确”,否则返回密码错误。 (2)输入字符‘2’,功能:设置密码。输入设置密码后,系统提示设置正确。 (3)输入字符‘3’,功能:显示密码。 (4)输入字符‘4’,功能:重置密码。密码重置为6个0; (5)输入字符‘0’,功能:系统退出。 (6)输入其他字符,系统提示输入错误请重新输入 C语言(403点数解答 | 2025-04-06 15:37:54)176
- import math class ball: """ 实现 def __init__(self, radius) 函数, 他有一个参数radius, 并为对象初始化一个变量self.radius """ """ 实现 def surface_area(self) 函数, 通过self.radius计算球的表面积, 并将这个表面积返回 """ """ 实现 def volume(self) 函数, 通过self.radius计算球的体积, 并将这个体积返回 """ """ 在评测文件中将这样调用这个类 ball = ball(eval(input())) print("球的半径:{:.2f}".format(ball.radius)) print("球的表面积:{:.2f}".format(ball.surface_area())) print("球的体积:{:(261点数解答 | 2024-11-28 21:19:39)206
- 3414 数字游戏 题目内容 全部提交 我的提交 题目统计 简单 时间限制: 1000ms 内存限制: 256mb 分数:100 oi排行榜得分:12(0.1*分数+2*难度) 字符串 第五讲(level1-2) 描述 小 k 同学向小 p 同学发送了一个长度为 8 的 01 字符串来玩数字游戏,小 p 同学想要知道字符串中究竟有多少个 1。 注意:01 字符串为每一个字符是 0 或者 1 的字符串,如“101”(不含双引号)为一个长度为 3 的 01 字符串。 输入描述 一个长度为 8 的 01 字符串 s。 输出描述 一个整数,即 01 字符串中字符 1 的个数。(106点数解答 | 2024-10-27 14:23:27)299
- 输入字符串数组words,每个字符串中间有且仅有一个空格,输入字符串prefix。输出在words中以prefix为前缀的数量。 class prefixtree: def __init__(self): self.table = [0] * 26 self.next = none def insert(self, s): current = self for ch in s: index = ord(ch) - ord('a') current.table[index] += 1 if current.next is none: current.next = prefixtree() current = current.next def count(self, s): current = self total_count = 0(259点数解答 | 2024-10-26 14:44:39)188