Python實現行列式計算

數學公式:
  

 


代碼:
# 逆序數
def getInversion(numlist):
    count = 0
    for i in range(1,len(numlist)):
        subscript = numlist[i]
        for j in range(i):
            if subscript < numlist[j]:
                count += 1
    return count
D = 0
# 全排列,求每項的積
def permutation(dd,ilist,jlist,index):
    global D
    for i in range(index,len(jlist)):
        if index == len(jlist)-1:
            term = 1
            for ii in range(len(ilist)):
                i = ilist[ii]
                j = jlist[ii]
                term *= dd[i][j]
            if getInversion(jlist) % 2 == 0:
                D += term
            else:D -= term
            return
        tmp = jlist[index]
        jlist[index] = jlist[i]
        jlist[i] = tmp
        permutation(dd,ilist,jlist,index+1)
        tmp = jlist[index]
        jlist[index] = jlist[i]
        jlist[i] = tmp

if __name__ == '__main__':
    dd = [[1, 2, -4], [-2, 2, 1], [-3, 4, -2]]
    dd =[[1,1,1,1],[-1,2,1,3],[1,4,1,9],[-1,8,1,27]]
    jlist = []
    ilist = []
    for ii in range(len(dd)):
        ilist.append(ii)
        jlist.append(ii)
    permutation(dd,ilist,jlist,0)
    print(D)
相關文章
相關標籤/搜索