当前位置: 首页 > news >正文

排版设计模板网站建设银行官方网站企业网银

排版设计模板网站,建设银行官方网站企业网银,企业培训系统app,网站代码怎么做文章目录 1.dp2.dp(单数组优化) LCS,Longest Common Subsequenc,最长公共子序列,子序列在原序列中可以不连续,但必须先后顺序保持一致。例如ABCD中,BD是一个子序列,DB不是。 LCS常被…

文章目录

  • 1.dp
  • 2.dp(单数组优化)

LCS,Longest Common Subsequenc,最长公共子序列,子序列在原序列中可以不连续,但必须先后顺序保持一致。例如ABCD中,BD是一个子序列,DB不是。

LCS常被用来计算文本相似度,其中的一种相似度计算方式:
在这里插入图片描述
这种计算方式的优点是可以平衡两文本长度差异,更公平。

1.dp

def lcs(s1, s2):"""定义状态:dp[i][j]表示s1前i个字符和s2前j个字符的最长公共子序列得到两种情况下的转移方程:1) s1[i-1]=s2[j-1]: 此时 dp[i][j]=dp[i-1][j-1]+12) s1[i-1]≠s2[j-1]: 此时 dp[i][j]=max(dp[i-1][j], dp[i][j-1])当i=0或j=0时,前i或前j个字符空字符串,所以最长子序列长度都为0:param s1::param s2::return:"""s1, s2 = ' ' + s1, ' ' + s2  # 添加占位符方便下标计算len_s1, len_s2 = len(s1), len(s2)dp = [[0] * len_s2] * len_s1for i in range(len_s1):for j in range(len_s2):if i * j == 0:continueif s1[i] == s2[j]:dp[i][j] = dp[i - 1][j - 1] + 1else:dp[i][j] = max(dp[i - 1][j], dp[i][j - 1])return dp[-1][-1], dp[-1][-1] * 2 / (len_s1 + len_s2)  # 返回lcs长度和相似度if __name__ == '__main__':addr1 = '北京市海淀区西北旺路10号'addr2 = '北京海淀西北旺路附近'print(lcs(addr1, addr2))# (8, 0.64)

这种实现方式需要双重循环遍历两个序列,所以时间复杂度和空间复杂度都是O(mn),m、n为两个序列的长度。

2.dp(单数组优化)

主要针对空间复杂度进行优化,上面实现方式构建的dp数组是m x n,可以通过下面单数组优化的方式将空间复杂度降到O(min(m, n))。

实现中以短文本的长度构建数组,外层循环遍历长文本,内层循环遍历短文本。下面代码为了方便没有做这个逻辑处理,空间复杂度是O(len(s2))。

def lcs(s1, s2):"""原来的二维数组的更新方式是从左到右,从上到下。、将这个二维数组想象成一个矩阵,每次更新一个dp[i][j]时,只参考了三个位置的值:1) dp[i-1][j-1]: 左上位置2) dp[i][j-1]: 左边位置3) dp[i-1][j]: 上方位置因此,只需要这个矩阵中j所在的数组长度就可以替代二维数组。定义dp[j]为s1与s2前j个元素的最长子序列长度,则没i轮迭代中dp[j]的值表示s1前i个字符和s2中前j个字符的最长子序列长度。因为数组是从左往右覆盖更新,因此:1) dp[j]=dp[i-1][j]    2) dp[j-1]=dp[i][j-1]此时只需要解决dp[i-1][j-1]位置的元素获取。设这个变量名left_up,每次外层循环初始为0,表示内层遍历的文本长度为0时的最长子序列长度。内层循环中,dp[j]在更新之前表示dp[i-1][j],因此只需要在每次dp[j]更新后将更新之前的dp[j]赋值给left_up,这样在下一个j的循环中left_up其实就是dp[i-1][j-1],也就是当前位置的左上角元素。:param s1::param s2::return:"""s1, s2 = ' ' + s1, ' ' + s2len_s1, len_s2 = len(s1), len(s2)dp = [0] * len_s2for i in range(len_s1):left_up = 0for j in range(len_s2):temp = dp[j]if i * j == 0:continueif s1[i] == s2[j]:dp[j] = left_up + 1else:dp[j] = max(dp[j - 1], dp[j])left_up = tempreturn dp[-1], dp[-1] * 2 / (len_s1 + len_s2)  # 返回lcs长度和相似度if __name__ == '__main__':addr1 = '北京市海淀区西北旺路10号'addr2 = '北京海淀西北旺路附近'print(lcs(addr1, addr2))# (8, 0.64)
http://www.dtcms.com/a/426277.html

相关文章:

  • 深圳市 交易建设中心网站网站制作域名是免费的吗
  • 宠物网站建设策划书wordpress底部版权怎么修改
  • 廊坊网站建设哪家好免费app软件下载网站
  • 用PS怎么做网站界面深圳定制专业网站
  • h5说 网站《网页制作与网站建设》
  • 东城网站设计网页如何设计跑马灯效果
  • 网站建设创业企业网站建设admin
  • 衡水建个网站多少钱制作自己的网站多少钱
  • 网站建设Skype打不开wordpress留言板源码
  • 做一个小网站多少钱江西冰溪建设集团网站
  • 电商网站开发需要掌握哪些知识技能购物网站备案费用
  • 小视频解析网站怎么做一级a做爰片51网站
  • 加强局门户网站建设展馆展示设计公司排名前十名
  • 网站建设知识学习心得大连网站建设咨询
  • 安阳网站制作优化如何用dw做网站
  • 汽车最专业的网站建设网站首页菜单栏模块怎么做的
  • 网站设计 wordpress网站建设必须要主机吗
  • 苏州网站建设主页外贸网站建设网站优化
  • 门户网站建设评标办法如何让百度快速收录
  • 威海经区建设局网站简单建设网站
  • 做网站的公司吉林市政建设招标网站有哪些
  • 国外的素材网站望野博物馆观后感
  • 做网站方面的问题做ui的网站有哪些
  • 昆山做网站公司哪家好网站上传
  • 西湖网站建设建筑公司网站宣传建筑工地文案范文图片
  • 网站公司图片梅州建站联系方式
  • 知名网站规划78创业商机网
  • 腾讯网站建设费用外贸seo优化公司
  • 网站开发项目的需求分析响应式网页设计原理
  • 注册网站域名网页设计基础填空题及答案