1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Python实现求矩阵的伴随矩阵

Python实现求矩阵的伴随矩阵

时间:2022-06-16 09:21:46

相关推荐

Python实现求矩阵的伴随矩阵

Python实现求矩阵的伴随矩阵

本文介绍如何使用python实现矩阵的输入并求出矩阵的伴随矩阵。

伴随矩阵

设有一矩阵A

设Aij是矩阵A中元素aij的代数余子式,那么矩阵A*

称为矩阵A的伴随矩阵

基本思路

先输入初始矩阵的阶数,再进行矩阵的录入

利用循环分别求矩阵每个元素对应的代数余子式,将所求结果按原对应位置组成新的矩阵,再进行转置,所求即初始矩阵的伴随矩阵

代码实现

import numpy as np#矩阵输入def arry_input(n,m):a = []b = []for i in range(n):for j in range(m):b.append(float(input()))a.append(b)b = []return a#矩阵转置def trans(m):a = [[] for i in m[0]]for i in m:for j in range(len(i)):a[j].append(i[j])return a#矩阵复制def copy(a):b = []c = []for i in range(len(a)):for j in range(len(a)):b.append(a[i][j])c.append(b)b = []return cn = int(input())#矩阵的阶数a = arry_input(n,n)#开始进行矩阵的输入b = []c = []d = []for i in range(n):for j in range(n):b = copy(a)for x in range(n):b[i][x] = 0for y in range(n):b[y][j] = 0#把aij元素的值变为1,其同行同列的其他元素变为0b[i][j] = 1 #求代数余子式的值,保留两位小数index = round(np.linalg.det(b),2)d.append(index)c.append(d)d = []print(trans(c))

需要注意的是

python中矩阵的复制不能简单地通过‘=’进行赋值,否则改变一个矩阵中元素的值,另一个矩阵中也会做出对应的改变

本代码还将每个元素的代数余子式的输出结果保留了两位小数,如对输出精度要求较高,可以自行调整

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。