逆矩陣的求法:
礦區網站建設公司創新互聯公司,礦區網站設計制作,有大型網站制作公司豐富經驗。已為礦區上千多家提供企業網站建設服務。企業網站搭建\成都外貿網站建設要多少錢,請找那個售后服務好的礦區做網站的公司定做!
1、利用定義求逆矩陣
設A、B都是n階方陣,?如果存在n階方陣B?使得AB=BA=E,?則稱A為可逆矩陣,?而稱B為A的逆矩陣。
2、運用初等行變換法
將一n階可逆矩陣A和n階單位矩陣I寫成一個nX2n的矩陣B=(A,I])對B施行初等行變換,即對A與I進行完全相同的若干初等行變換,目標是把A化為單位矩陣。當A化為單位矩陣I的同時,B的右一半矩陣同時化為了A的逆矩陣。
3、增廣矩陣法
如果要求逆的矩陣是A,則對增廣矩陣(A E)進行初等行變換,E是單位矩陣,將A化到E,此時此矩陣的逆就是原來E的位置上的那個矩陣,原理是 A逆乘以(A E)= (E A逆)初等行變換就是在矩陣的左邊乘以A的逆矩陣得到的。
4、待定系數法
待定系數法顧名思義就是對未知數進行求解。用一個新的包含未定因子的多項式來表達多項式,從而獲得一個恒等式。接著,利用恒等式的特性,推導出一類系數必須滿足的方程或方程,再由方程組或方程組得到待確定的系數,或確定各系數之間的對應關系,稱為待定系數法。
矩陣求逆的VB程序
Private Function MRinv(N As Integer, mtxA() As Double) As Boolean
'****************************************************************************************
' 功能: 實現矩陣求逆的全選主元高斯-約當法
' 參數: n - Integer型變量,矩陣的階數
' mtxA - Double型二維數組,體積為n x n。存放原矩陣A;返回時存放其逆矩陣A-1。
' 返回值:Boolean型,失敗為False,成功為True
'****************************************************************************************
ReDim nIs(N) As Integer, nJs(N) As Integer
Dim i As Integer, j As Integer, k As Integer
Dim D As Double, p As Double
' 全選主元,消元
For k = 1 To N
D = 0#
For i = k To N
For j = k To N
p = Abs(mtxA(i, j))
If (p D) Then
D = p
nIs(k) = i
nJs(k) = j
End If
Next j
Next i
' 求解失敗
If (D + 1# = 1#) Then
MRinv = False
Exit Function
End If
If (nIs(k) k) Then
For j = 1 To N
p = mtxA(k, j)
mtxA(k, j) = mtxA(nIs(k), j)
mtxA(nIs(k), j) = p
Next j
End If
If (nJs(k) k) Then
For i = 1 To N
p = mtxA(i, k)
mtxA(i, k) = mtxA(i, nJs(k))
mtxA(i, nJs(k)) = p
Next i
End If
mtxA(k, k) = 1# / mtxA(k, k)
For j = 1 To N
If (j k) Then mtxA(k, j) = mtxA(k, j) * mtxA(k, k)
Next j
For i = 1 To N
If (i k) Then
For j = 1 To N
If (j k) Then mtxA(i, j) = mtxA(i, j) - mtxA(i, k) * mtxA(k, j)
Next j
End If
Next i
For i = 1 To N
If (i k) Then mtxA(i, k) = -mtxA(i, k) * mtxA(k, k)
Next i
Next k
' 調整恢復行列次序
For k = N To 1 Step -1
If (nJs(k) k) Then
For j = 1 To N
p = mtxA(k, j)
mtxA(k, j) = mtxA(nJs(k), j)
mtxA(nJs(k), j) = p
Next j
End If
If (nIs(k) k) Then
For i = 1 To N
p = mtxA(i, k)
mtxA(i, k) = mtxA(i, nIs(k))
mtxA(i, nIs(k)) = p
Next i
End If
Next k
' 求解成功
MRinv = True
End Function
來源:
1采用二維數組存放矩陣各元素值
2根據數矩陣運算規則進行相應計算
求逆矩陣的簡便方法如下:
1、待定系數法。
2、伴隨矩陣求逆矩陣。
3、初等變換求逆矩陣。
待定系數法,一種求未知數的方法。將一個多項式表示成另一種含有待定系數的新的形式,這樣就得到一個恒等式。然后根據恒等式的性質得出系數應滿足的方程或方程組,其后通過解方程或方程組便可求出待定的系數,或找出某些系數所滿足的關系式。
伴隨矩陣是矩陣元素所對應的代數余子式,所構成的矩陣,轉置后得到的新矩陣。我們先求出伴隨矩陣A*=-3,-2,1 , 1。接下來,求出矩陣A的行列式|A|=1*(-3) - (-1)* 2=-3+2=-1。從而逆矩陣A?1=A*/|A| =A*/(-1)=-A*=3, 2,-1,-1。
初等變換求逆矩陣首先,寫出增廣矩陣A|E,即矩陣A右側放置一個同階的單位矩陣,得到一個新矩陣。
1,2,1,0,-1,-3,0,1。然后進行初等行變換。依次進行第1行加到第2行,得到1,2,1,0,0,-1,1,1。第2行×2加到第1行,得到1,0,3,2,0,-1,1,1。第2行×(-1),得到1,0,3,2,0,1,-1,-1。
Function Rect_yu(A() As Double, L As Long, C() As Double) As Double 矩陣求逆 Dim T0 As Double Dim T1 As Double Dim T2 As Double Dim T3 As Double Dim B() As Double Dim Num As Double Dim Chay As Long Dim Chax As Long Chay = 0 Chax = 0 ReDim B(L - 1, L - 1) Num = 0 Dim add As Double add = 1 / Rect(A(), L) For T0 = 0 To L For T3 = 0 To L For T1 = 0 To L - 1 If T1 T0 Then Chax = 0 Else Chax = 1 End If For T2 = 0 To L - 1 If T2 T3 Then Chay = 0 Else Chay = 1 End If B(T1, T2) = A(T1 + Chax, T2 + Chay) Next T2 Next T1 Rect(B(), L - 1) 調用求行列式值 C(T3, T0) = Rect(B(), L - 1) * add * ((-1) ^ (T0 + T3)) Next T3 Next T0End Function
網頁標題:vb.net矩陣求逆 用c語言求逆矩陣
分享鏈接:http://m.newbst.com/article30/hjpgso.html
成都網站建設公司_創新互聯,為您提供建站公司、營銷型網站建設、電子商務、網站導航、網站改版、手機網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯