Heim >Backend-Entwicklung >Python-Tutorial >Detailliertes Beispiel dafür, wie Python die Teilmengenbaumvorlage der Backtracking-Methode verwendet, um das längste häufige Teilsequenzproblem zu erhalten

Detailliertes Beispiel dafür, wie Python die Teilmengenbaumvorlage der Backtracking-Methode verwendet, um das längste häufige Teilsequenzproblem zu erhalten

巴扎黑
巴扎黑Original
2017-09-09 10:30:321660Durchsuche

In diesem Artikel wird hauptsächlich vorgestellt, wie Python die Teilmengenbaumvorlage der Backtracking-Methode verwendet, um die längste gemeinsame Teilsequenz (LCS) zu erhalten. Er beschreibt kurz das Problem der längsten gemeinsamen Teilsequenz und analysiert Python anhand der Teilmengenbaumvorlage der Backtracking-Methode in Form von Beispielen . Für die Schritte und zugehörigen Vorsichtsmaßnahmen zum Erhalten der längsten gemeinsamen Teilsequenz können sich Freunde in Not auf

beziehen. In diesem Artikel wird beschrieben, wie Python die Backtracking-Teilmengenbaumvorlage verwendet, um die längste gemeinsame Teilsequenz (LCS) zu erhalten. Teilen Sie es als Referenz mit allen. Die Details lauten wie folgt:

Frage

Eintreten

Nr. 1 Zeile: Zeichenfolge A
Zeile 2: Zeichenfolge B
(Länge von A,B

Ausgabe

Ausgabe die meisten Bei langen Teilsequenzen geben Sie, wenn mehrere vorhanden sind, eine nach Belieben aus.

Eingabebeispiel

belong
cnblogs

Ausgabebeispiel

Blog

Analyse

Da Sie planen, die Backtracking-Teilmengenbaumvorlage anzuwenden, müssen Sie die Methode der Elementzustandsraumanalyse verwenden.

Verwenden Sie die Zeichen in der Zeichenfolge mit einer kleineren Länge als Elemente und die Zeichen in der Zeichenfolge mit einer größeren Länge als Zustandsraum. Durchqueren Sie für jedes Element seinen Zustandsraum und überlassen Sie andere Dinge der Scherung Funktion! ! !

Die Länge der Lösung x ist nicht festgelegt und xi stellt die Sequenznummer in Zeichenfolge b dar.

Wenn bei der Verarbeitung jedes Elements kein Status ausgewählt ist (kein Zeichen in cnblogs ausgewählt ist), kann das Programm nicht zum nächsten Element wechseln.

Das ist in der Tat ein großes Problem! ! ! Nachdem ich einen Tag lang nachgedacht hatte, fand ich endlich einen Weg: Erweitern Sie den Zustandsraum und fügen Sie einen Zustand q hinzu! Wenn das Element den Zustand q auswählt, ist es zulässig. Der Zustand q wird jedoch nicht zur Lösung x hinzugefügt! ! !

Sehen Sie sich ein intuitives Bild an:

An diesem Punkt genießen Sie es!

Code


'''最长公共子序列'''
# 作者:hhh5460
# 时间:2017年6月3日
a = 'belong'
b = 'cnblogs'
x = []  # 一个解(长度不固定)xi是b中字符的序号
X = []  # 一组解
best_x = [] # 最佳解
best_len = 0 # 最大子序列长度
# 冲突检测
def conflict(k):
  global n, x, X, a,b,best_len
  # 如果两个字符不相等
  if x[-1] < len(b) and a[k] != b[x[-1]]:
    return True
  # 如果两个字符相等,但是相对于前一个在b中的位置靠前
  if a[k] == b[x[-1]] and (len(x) >= 2 and x[-1] <= x[-2]):
    return True
  # 如果部分解的长度加上后面a剩下的长度,小于等于best_len
  if len(x) + (len(a)-k) < best_len:
    return True
  return False # 无冲突
# 回溯法(递归版本)
def LCS(k): # 到达a中的第k个元素
  global x, X,a,b,best_len,best_x
  #print(k, x)
  if k == len(a): # 超出最尾的元素
    if len(x) > best_len:
      best_len = len(x)
      best_x = x[:]
  else:
    for i in range(len(b)+1): # 遍历 状态空间:0~len(b)-1,技巧:人为增加一种状态len(b),表示改行没有元素选取
      if i==len(b): # 此状态不放入解x内
        LCS(k+1)
      else:
        x.append(i)
        if not conflict(k): # 剪枝
          LCS(k+1)
        x.pop()       # 回溯
# 根据一个解x,构造最长子序列lcs
def get_lcs(x):
  global b
  return &#39;&#39;.join([b[i] for i in x])
# 测试
LCS(0)
print(b)
print(best_x)
print(get_lcs(best_x))

Rendering

Das obige ist der detaillierte Inhalt vonDetailliertes Beispiel dafür, wie Python die Teilmengenbaumvorlage der Backtracking-Methode verwendet, um das längste häufige Teilsequenzproblem zu erhalten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn