【算法进阶2-动态规划】最长公共子序列、欧几里得算法-分数、RSA算法-密码于加密

1 最长公共子序列
2 欧几里得算法
2.1 欧几里得算法-分数
3 RSA算法-密码于加密

1 最长公共子序列

在这里插入图片描述

-个序列的子序列是在该序列中删去若干元素后得 到的序列。
例:“ABCD”和“BDF”都是“ABCDEFG”的子序列最长公共子序列(LCS)问题:给定两个序列X和Y,求X和Y长度最大的公共子序列。
例:X="ABBCBDE" Y="DBBCDB" LCS(X,Y)="BBCD"应用场景:字符串相似度比对

在这里插入图片描述

from typing import Tupledef lcs_length(x: str, y: str) -> int:"""计算两个字符串的最长公共子序列 (LCS) 的长度。使用动态规划方法解决LCS问题。LCS问题是指在两个字符串中找到一个最长的子序列,使得这个子序列在两个字符串中都出现,并且保持其相对顺序不变。:param x: 第一个字符串:param y: 第二个字符串:return: 返回两个字符串的最长公共子序列的长度"""m = len(x)  # 第一个字符串的长度n = len(y)  # 第二个字符串的长度# 创建一个 (m+1) x (n+1) 的二维列表 c,用于存储子问题的解# c[i][j] 表示字符串 x 的前 i 个字符和字符串 y 的前 j 个字符的最长公共子序列的长度c = [[0 for _ in range(n + 1)] for _ in range(m + 1)]# 填充二维列表 cfor i in range(1, m + 1):  # 遍历字符串 x 的每个字符for j in range(1, n + 1):  # 遍历字符串 y 的每个字符if x[i - 1] == y[j - 1]:  # 如果 x 的第 i 个字符等于 y 的第 j 个字符# 如果字符匹配,当前最长公共子序列的长度是左上角的值 + 1c[i][j] = c[i - 1][j - 1] + 1else:# 如果字符不匹配,取上方或左方的最大值c[i][j] = max(c[i - 1][j], c[i][j - 1])# 打印二维列表 c 的值(用于调试)for _ in c:print('列表的值是:', _)# 返回最长公共子序列的长度,即 c[m][n]return c[m][n]# print(lcs_length("ABCBDAB", "BDCABA"))  # 4# 列表的值是: [0, 0, 0, 0, 0, 0, 0]
# 列表的值是: [0, 0, 0, 0, 1, 1, 1]
# 列表的值是: [0, 1, 1, 1, 1, 2, 2]
# 列表的值是: [0, 1, 1, 2, 2, 2, 2]
# 列表的值是: [0, 1, 1, 2, 2, 3, 3]
# 列表的值是: [0, 1, 2, 2, 2, 3, 3]
# 列表的值是: [0, 1, 2, 2, 3, 3, 4]
# 列表的值是: [0, 1, 2, 2, 3, 4, 4]def lcs(x: str, y: str) -> Tuple[int, list]:"""计算两个字符串的最长公共子序列 (LCS) 的长度,并生成动态规划表。使用动态规划方法求解两个字符串的最长公共子序列问题,并返回长度以及记录方向的表,用于后续的LCS路径恢复。:param x: 第一个字符串:param y: 第二个字符串:return: 返回一个元组,包含两个元素:- LCS的长度- 动态规划表 b,其中 b[i][j] 表示到达位置 (i, j) 时的方向"""m = len(x)  # 第一个字符串的长度n = len(y)  # 第二个字符串的长度# 创建一个 (m+1) x (n+1) 的二维列表 c,用于存储子问题的解# c[i][j] 表示字符串 x 的前 i 个字符和字符串 y 的前 j 个字符的最长公共子序列的长度c = [[0 for _ in range(n + 1)] for _ in range(m + 1)]# 创建一个 (m+1) x (n+1) 的二维列表 b,用于记录方向# b[i][j] 表示到达位置 (i, j) 时的方向# "←" 表示来自左上方(匹配),# "↑" 表示来自上方(不匹配,向上移动),# "↖" 表示来自左方(不匹配,向左移动)b = [['*' for _ in range(n + 1)] for _ in range(m + 1)]# 填充二维列表 c 和 bfor i in range(1, m + 1):for j in range(1, n + 1):if x[i - 1] == y[j - 1]:  # 如果 x 的第 i 个字符等于 y 的第 j 个字符# 如果字符匹配,当前最长公共子序列的长度是左上角的值 + 1c[i][j] = c[i - 1][j - 1] + 1b[i][j] = "←"  # 方向来自于左上方(匹配)elif c[i - 1][j] > c[i][j - 1]:  # 如果来自上方的值大于来自左方的值# 如果上方的值更大,选择上方的值c[i][j] = c[i - 1][j]b[i][j] = "↑"  # 方向来自于上方(不匹配,向上移动)else:# 如果左方的值更大或相等,选择左方的值c[i][j] = c[i][j - 1]b[i][j] = "↖"  # 方向来自于左方(不匹配,向左移动)# 返回最长公共子序列的长度和方向记录表return c[m][n], bc, b = lcs("ABCBDAB", "BDCABA")
for _ in b:print(_)# ['*', '*', '*', '*', '*', '*', '*']
# ['*', '↖', '↖', '↖', '←', '↖', '←']
# ['*', '←', '↖', '↖', '↖', '←', '↖']
# ['*', '↑', '↖', '←', '↖', '↖', '↖']
# ['*', '←', '↖', '↑', '↖', '←', '↖']
# ['*', '↑', '←', '↖', '↖', '↑', '↖']
# ['*', '↑', '↑', '↖', '←', '↖', '←']
# ['*', '←', '↑', '↖', '↑', '←', '↖']def lcs_traceback(x: str, y: str) -> str:"""根据动态规划表回溯,找出两个字符串的最长公共子序列 (LCS)。使用动态规划表 `b` 来回溯最长公共子序列的路径,并从结果表 `c` 中获取最长公共子序列的字符。最终返回最长公共子序列的字符串。:param x: 第一个字符串:param y: 第二个字符串:return: 返回两个字符串的最长公共子序列(LCS)的字符串表示"""# 调用 lcs 函数获取动态规划表 c 和方向记录表 bc, b = lcs(x, y)i = len(x)  # 初始化 i 为第一个字符串的长度j = len(y)  # 初始化 j 为第二个字符串的长度res = []  # 用于存储回溯得到的 LCS 字符# 根据方向记录表 b 从表的右下角开始回溯到左上角while i > 0 and j > 0:if b[i][j] == "←":# 如果方向来自于左上方(匹配),则当前字符是 LCS 的一部分res.append(x[i - 1])i -= 1  # 移动到前一个字符j -= 1  # 移动到前一个字符elif b[i][j] == "↑":# 如果方向来自于上方,则移动到上方的子问题i -= 1else:  # '↖'# 如果方向来自于左方,则移动到左方的子问题j -= 1# 由于回溯过程中字符是从 LCS 的末尾开始添加的,所以需要反转结果列表return "".join(res[::-1])print(lcs_traceback("ABCBDAB", "BDCABA"))  # BDAB

2 欧几里得算法

在这里插入图片描述
在这里插入图片描述

def gcd(a: int, b: int) -> int:"""递归求解两个数的最大公约数 (GCD)。使用欧几里得算法通过递归的方式计算两个整数的最大公约数。当第二个数 b 为 0 时,最大公约数是第一个数 a。:param a: 第一个整数:param b: 第二个整数:return: 返回 a 和 b 的最大公约数"""if b == 0:return a  # 基本情况:当 b 为 0 时,a 是最大公约数else:# 递归调用:计算 b 和 a % b 的最大公约数return gcd(b, a % b)print(gcd(12, 16))  # 4def gcd2(a: int, b: int) -> int:"""非递归求解两个数的最大公约数 (GCD)。使用欧几里得算法通过迭代的方式计算两个整数的最大公约数。通过不断更新 a 和 b 直到 b 为 0,此时 a 就是最大公约数。:param a: 第一个整数:param b: 第二个整数:return: 返回 a 和 b 的最大公约数"""while b > 0:r = a % b  # 计算 a 除以 b 的余数a = b  # 更新 a 为 bb = r  # 更新 b 为余数return a  # 当 b 为 0 时,a 是最大公约数print(gcd2(12, 16))  # 4

2.1 动态规划之欧几里得算法-分数

class Fraction:def __init__(self, a: int, b: int):"""初始化一个分数对象,并将其化简为最简分数。:param a: 分子:param b: 分母"""self.a = aself.b = b# 计算最大公约数x = self.gcd(a, b)# 将分子和分母除以最大公约数,化简为最简分数self.a /= xself.b /= x@staticmethoddef gcd(a: int, b: int) -> int:"""非递归求解两个数的最大公约数 (GCD)。使用欧几里得算法通过迭代的方式计算两个整数的最大公约数。通过不断更新 a 和 b 直到 b 为 0,此时 a 就是最大公约数。:param a: 第一个整数:param b: 第二个整数:return: 返回 a 和 b 的最大公约数"""while b > 0:r = a % b  # 计算 a 除以 b 的余数a = b  # 更新 a 为 bb = r  # 更新 b 为余数return a  # 当 b 为 0 时,a 是最大公约数def __str__(self) -> str:"""返回分数的字符串表示形式。:return: 返回分数的字符串表示,例如 "3/4""""return f"{int(self.a)}/{int(self.b)}"@staticmethoddef zgs(a: int, b: int) -> int:"""计算两个数的最小公倍数 (Least Common Multiple, LCM)。使用公式 LCM(a, b) = abs(a * b) / GCD(a, b) 来计算最小公倍数。:param a: 第一个整数:param b: 第二个整数:return: 返回 a 和 b 的最小公倍数,类型为整数"""x = Fraction.gcd(a, b)  # 调用静态方法 gcd 计算最大公约数return a * b // x  # 根据公式计算最小公倍数,使用整数除法返回整数结果def __add__(self, other: 'Fraction') -> 'Fraction':# 3/5 + 2/7"""重载加法运算符,实现两个分数相加。通过计算两个分数的最小公倍数来统一分母,并计算新分数的分子。:param self: 第一个分数对象:param other: 第二个分数对象:return: 返回两个分数相加后的结果,作为新的 Fraction 对象"""a = self.a  # 当前分数的分子b = self.b  # 当前分数的分母c = other.a  # 另一个分数的分子d = other.b  # 另一个分数的分母denominator = self.zgs(b, d)  # 计算两个分数分母的最小公倍数numerator = a * denominator // b + c * denominator // d  # 计算新分数的分子,使用整数除法确保结果为整数return Fraction(int(numerator), int(denominator))  # 返回新的 Fraction 对象,表示两个分数相加的结果# f = Fraction(30, 16)
# print(f)  # 输出 15/8a = Fraction(3, 4)
b = Fraction(1, 2)
print(a + b)  # 5/6

3 RSA算法-密码于加密

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/51295.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Hadoop的概念

目录 1.什么是大数据 2.Hadoop体系结构 1:HDFS(Hadoop Distributed File System) 2 :MapReduce 3:YARN(Yet Another Resource Negotiator) 3、Hadoop生态圈 4、MapReduce的原理和工作流程…

android gradle 配置国内gradle地址

1. 地址: 腾讯云镜像 Gradle下载地址:https://mirrors.cloud.tencent.com/gradle/ 阿里云镜像 Gradle下载地址:https://mirrors.aliyun.com/macports/distfiles/gradle/ 阿里云镜像 Gradle下载地址:https://mirrors.aliyun.com…

浪潮服务器主板集成RAID常见问题

★主板集成RAID出现Initialize初始化,如下图 判断及解决方案: 1.机器是否有过插拔硬盘等操作。 2.系统初始化-系统启动会非常的慢。一般为非法关机或者断电导致。 3.出现此情况耐心等待磁盘初始化完成即可。系统初始化时间以具体的数据大小来决定&#…

Linux启动流程和Systemd特性

文章目录 内核设计流派linux启动流程1.硬件加电自检2.启动加载器bootloader3.加载kernel4.init初始化5.用户终端启动 systemdsystemd特性systemd的unitunit配置文件 systemctl管理系统服务service unit服务状态 service unit文件格式Unit段Service段Install段 内核设计流派 1.…

android 实现简易音乐播放器

音乐App 源代码 : 简易音乐APP源代码 1、简介 一个简易的音乐APP,主要练习对四大组件的应用。感兴趣的可以看看。 播放界面如下: 歌曲列表界面如下: 项目结构如下: 接下来将对代码做详细介绍: 2、Musi…

【SpringCloud Alibaba】(九)学习 Gateway 服务网关

目录 1、网关概述1.1、没有网关的弊端1.2、引入 API 网关 2、主流的 API 网关2.1、NginxLua2.2、Kong 网关2.3、Zuul 网关2.4、Apache Shenyu 网关2.5、SpringCloud Gateway 网关 3、SpringCloud Gateway 网关3.1、Gateway 概述3.2、Gateway 核心架构 4、项目整合 SpringCloud …

大模型在应用开发安全左移实践

1.应用开发安全左移势在必行 近年来,应用系统被入侵或敏感信息泄漏类的安全事件时有发生,大部分安全事件的根本原因是应用软件设计或实现中存在安全漏洞。由于软件安全性问题导致各种信息泄密、信息被篡改、网络服务中断的事件频发,给企业和…

C# 泛型类型的约束详解与示例

文章目录 一、泛型约束概述二、泛型约束详解与示例1. 类约束2. 接口约束3. 引用类型约束4. 值类型约束5. 无参数构造函数约束6、多重约束7、默认构造函数约束8、基类和接口的组合约束 三、总结 在C#编程语言中,泛型是一种非常强大的特性,它允许我们编写可…

图解Redis五大数据类型

五种数据类型的不同之处&#xff0c;是value在存储时的形式不同。 hash类型 value类型是<key,value>键值对。如果发生hash冲突&#xff0c;用开放定址法解决&#xff0c;不拉链&#xff01; key值重复&#xff0c;则新值覆盖旧值 List类型 Set类型 与List的类似&…

3款一键AI智能改写软件,轻松改出高质量文章 tzq

随着科技的不断发展&#xff0c;人工智能技术正逐渐渗透到各个领域。在写作方面&#xff0c;一键AI智能改写软件的出现&#xff0c;为人们提供了更加便捷高效的写作工具。无论是写作初学者还是专业作家&#xff0c;都可以通过这些软件轻松改写出高质量的文章。本文将介绍三款优…

查找数学类文献的专业数据库有哪些 如何获取这些数据库资源

一、MathSciNet&#xff08;美国数学会《数学评论》&#xff09; MathSciNet数据库是美国数学学会出版的《数学评论》Mathematical Reviews和Current Mathematical Publications的网络版&#xff0c;包含《数学评论》自1940年出版以来的所有评论文章&#xff0c;包括期刊、图书…

【AI+编程】只需1句提示词0代码生成前端展示效果

最近被Vercel发布的V0 编程效果惊艳到了&#xff0c; 不管是前端开发 还是立志成为全栈工程师的 同学&#xff0c;不可错过。 官网地址&#xff1a;https://v0.dev/chat/ 代码生成工具很多&#xff0c;不管是github copilot、阿里的通义灵码&#xff0c; 腾讯云的AI代码助手…

PyTorch升级之旅——主要组成模块

本文仅作为个人学习记录使用 文章目录 前言 一、深度学习的简单流程 二、基本配置 三、数据读入 四、模型构建 五、模型初始化 六、损失函数 七、训练和评估 八、可视化 九、PyTorch优化器 总结 前言 学习链接&#xff1a;第三章&#xff1a;PyTorch的主要组成模块…

leetcode 80 删除有序数组中的重复项 II

正文 仍旧使用双指针&#xff0c; 思想与 leetcode 26 删除有序数组中的重复项 一致。只是此时因为要求保留重复元素两次&#xff0c;我们的左侧指针可以从第二个数据开始&#xff0c;且右侧指针需要和两个元素的值进行判断。 class Solution:def removeDuplicates(self, nums…

深度学习入门:循环神经网络------RNN概述,词嵌入层,循环网络层及案例实践!(万字详解!)

目录 &#x1f354; RNN 概述 1.1 循环神经网络 1.2 自然语言处理 &#x1f354; 词嵌入层 2.1 词嵌入层的使用 2.2 关于词嵌入层的思考 2.3 小节 &#x1f354; 循环网络层 3.1 RNN 网络原理 3.1.1 RNN计算过程 3.1.2 如何计算神经元内部 3.2 PyTorch RNN 层的使用…

Flask返回Json格式字符,中文导致unicode乱码问题

一.问题描述 或者直接返回json格式的字符串 从上图可以看出&#xff0c;当flask实现的接口响应中存在中文时&#xff0c;接口返回json字串的中文为unicode乱码。 二.问题解决 百度搜索了很多&#xff0c;原来在创建flask app时使用json格式的字符串&#xff0c;默认是ascii编…

字节微前端框架Garfish

Garfish 是字节跳动开源的微前端框架&#xff0c;旨在应对现代 Web 应用在前端生态繁荣与应用日益复杂化背景下的挑战。本文将介绍如何使用 Garfish&#xff0c;提供代码示例&#xff0c;并与另一流行的微前端框架 Qiankun 进行对比分析。 安装 Garfish 首先&#xff0c;安装…

快速排序模版

1.霍尔法 #include <iostream> using namespace std; int partition(int *arr,int left,int right){int pivotIndexleft;while(left<right){while(left<right && arr[right]>arr[pivotIndex]){right--;}while(left<right && arr[left]<a…

vTable实现多维表格

介绍 vTable是字节开发的一款能用来渲染表格的库&#xff0c;是用canvas渲染&#xff0c;避免了传统用dom组件表格的一些问题&#xff0c;能很快的渲染出上万格子的表格。 接下来我将使用vTable构建类似下面的多维表格&#xff0c;其中quantity、sales等是指标。 使用 官网地址…