【算法】LCS 最长子字符串

1 篇文章 0 订阅

说明:最长字串指两字符串中按序但不要求相邻的最长公共部分
比如:“ABSD”与“ASBD”的最长字串为“ASD”

一、递推关系

在这里插入图片描述

二、数据结构

在这里插入图片描述

三、代码实现
#coding:u8
import numpy as np
def LCS(s1,s2):
	C=np.zeros((len(s1)+1,len(s2)+1),np.uint8)
	B=np.empty((len(s1)+1,len(s2)+1), np.dtype('U25'))
	for i in range(1,len(s1)+1):
		for j in range(1,len(s2)+1):
			if s1[i-1]==s2[j-1]:
				C[i,j]=C[i-1,j-1]+1
				B[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]="←"
	print(C)
	print(B)
	maxSubStr=""
	def getStr(i,j):
		nonlocal maxSubStr
		if i==0 or j==0:
			return
		if B[i,j]=="↖":		
			maxSubStr+=s1[i-1]
			getStr(i-1,j-1) 		
		elif B[i,j]=="↑":
			getStr(i-1,j)
		else:
			getStr(i,j-1)
	getStr(len(s1),len(s2))
	print("最长子字符串为:",maxSubStr)

输出结果

[[0 0 0 0 0 0 0 0 0 0 0 0]
 [0 1 1 1 1 1 1 1 1 1 1 1]
 [0 1 1 2 2 2 2 2 2 2 2 2]
 [0 1 1 2 2 3 3 3 3 3 3 3]
 [0 1 2 2 2 3 4 4 4 4 4 4]
 [0 1 2 2 2 3 4 4 4 4 4 4]
 [0 1 2 3 3 3 4 5 5 5 5 5]
 [0 1 2 3 3 3 4 5 5 5 5 5]
 [0 1 2 3 3 4 4 5 5 5 5 6]
 [0 1 2 3 3 4 5 5 5 5 5 6]
 [0 1 2 3 3 4 5 6 6 6 6 6]]
[['' '' '' '' '' '' '' '' '' '' '' '']
 ['' '↖' '←' '←' '←' '↖' '←' '←' '←' '←' '←' '↖']
 ['' '↑' '←' '↖' '←' '←' '←' '↖' '←' '←' '←' '←']
 ['' '↖' '←' '↑' '←' '↖' '←' '←' '←' '←' '←' '↖']
 ['' '↑' '↖' '←' '←' '↑' '↖' '←' '←' '←' '←' '←']
 ['' '↑' '↑' '←' '←' '↑' '↑' '←' '←' '←' '←' '←']
 ['' '↑' '↑' '↖' '←' '←' '↑' '↖' '←' '←' '←' '←']
 ['' '↑' '↑' '↑' '←' '←' '↑' '↑' '←' '←' '←' '←']
 ['' '↖' '↑' '↑' '←' '↖' '←' '↑' '←' '←' '←' '↖']
 ['' '↑' '↖' '↑' '←' '↑' '↖' '←' '←' '←' '←' '↑']
 ['' '↑' '↑' '↖' '←' '↑' '↑' '↖' '←' '←' '←' '←']]
最长子字符串为: CSACSA
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值