> 백엔드 개발 > 파이썬 튜토리얼 > Python最长公共子串算法实例

Python最长公共子串算法实例

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-10 15:17:37
원래의
1823명이 탐색했습니다.

本文实例讲述了Python最长公共子串算法。分享给大家供大家参考。具体如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

#!/usr/bin/env python

# find an LCS (Longest Common Subsequence).

# *public domain*

  

def find_lcs_len(s1, s2):

 m = [ [ 0 for x in s2 ] for y in s1 ]

 for p1 in range(len(s1)):

  for p2 in range(len(s2)):

   if s1[p1] == s2[p2]:

    if p1 == 0 or p2 == 0:

     m[p1][p2] = 1

    else:

     m[p1][p2] = m[p1-1][p2-1]+1

   elif m[p1-1][p2] < m[p1][p2-1]:

    m[p1][p2] = m[p1][p2-1]

   else:               # m[p1][p2-1] < m[p1-1][p2]

    m[p1][p2] = m[p1-1][p2]

 return m[-1][-1]

  

def find_lcs(s1, s2):

 # length table: every element is set to zero.

 m = [ [ 0 for x in s2 ] for y in s1 ]

 # direction table: 1st bit for p1, 2nd bit for p2.

 d = [ [ None for x in s2 ] for y in s1 ]

 # we don't have to care about the boundery check.

 # a negative index always gives an intact zero.

 for p1 in range(len(s1)):

  for p2 in range(len(s2)):

   if s1[p1] == s2[p2]:

    if p1 == 0 or p2 == 0:

     m[p1][p2] = 1

    else:

     m[p1][p2] = m[p1-1][p2-1]+1

    d[p1][p2] = 3          # 11: decr. p1 and p2

   elif m[p1-1][p2] < m[p1][p2-1]:

    m[p1][p2] = m[p1][p2-1]

    d[p1][p2] = 2          # 10: decr. p2 only

   else:               # m[p1][p2-1] < m[p1-1][p2]

    m[p1][p2] = m[p1-1][p2]

    d[p1][p2] = 1          # 01: decr. p1 only

 (p1, p2) = (len(s1)-1, len(s2)-1)

 # now we traverse the table in reverse order.

 s = []

 while 1:

  print p1,p2

  c = d[p1][p2]

  if c == 3: s.append(s1[p1])

  if not ((p1 or p2) and m[p1][p2]): break

  if c & 2: p2 -= 1

  if c & 1: p1 -= 1

 s.reverse()

 return ''.join(s)

  

if __name__ == '__main__':

 print find_lcs('abcoisjf','axbaoeijf')

 print find_lcs_len('abcoisjf','axbaoeijf')

로그인 후 복사

希望本文所述对大家的Python程序设计有所帮助。

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿