2015-02-23 147 views
1

我需要創建一個計算LCS然後打印出來的矩陣。這是我的代碼,但我無法與打印功能(不知道如何讓LCSmatrix值到打印)Python:構造和打印矩陣

def compute_LCS(seqA, seqB): 

    for row in seqA: 
    for col in seqB: 
     if seqA[row] == seqB[col]: 
      if row==0 or col==0: 
       LCSmatrix(row,col) = 1 
      else: 
       LCSmatrix(row,col) = LCS(row-1,col-1) + 1 
     else: 
      LCSmatrix(row,col) = 0 
return LCSmatrix 


def printMatrix(parameters...): 
    print ' ', 
    for i in seqA: 
      print i, 
    print 
    for i, element in enumerate(LCSMatrix): 
      print i, ' '.join(element) 

matrix = LCSmatrix 


print printMatrix(compute_LCS(seqA,seqB)) 

任何幫助將非常感激。

回答

0

試試這個:

seqA='AACTGGCAG' 
seqB='TACGCTGGA' 

def compute_LCS(seqA, seqB): 
    LCSmatrix = [len(seqB)*[0] for row in seqA] 
    for row in range(len(seqB)): 
     for col in range(len(seqA)): 
      if seqB[row] == seqA[col]: 
       if row==0 or col==0: 
        LCSmatrix[row][col] = 1 
       else: 
        LCSmatrix[row][col] = LCSmatrix[row-1][col-1] + 1_ 
      else: 
       LCSmatrix[row][col] = 0 
    return LCSmatrix 

def printMatrix(seqA, seqB, LCSmatrix): 
    print ' '.join('%2s' % x for x in ' '+seqA) 
    for i, element in enumerate(LCSmatrix): 
     print '%2s' % seqB[i], ' '.join('%2i' % x for x in element) 

matrix = compute_LCS(seqA, seqB) 
printMatrix(seqA, seqB, matrix) 

上述方法產生:

A A C T G G C A G 
T 0 0 0 1 0 0 0 0 0 
A 1 1 0 0 0 0 0 1 0 
C 0 0 2 0 0 0 1 0 0 
G 0 0 0 0 1 1 0 0 1 
C 0 0 1 0 0 0 2 0 0 
T 0 0 0 2 0 0 0 0 0 
G 0 0 0 0 3 1 0 0 1 
G 0 0 0 0 1 4 0 0 1 
A 1 1 0 0 0 0 0 1 0 
+0

哇哦,太感謝你了!我現在明白你是如何通過打印功能的參數。我還會看到如何爲compute_LCS函數創建第一條LCSmatrix線。 – 2015-02-23 06:50:05