高斯消元法python编程_Python高斯消去法

超级新的编程和仍在学习如何调试。每次我运行这个高斯消去程序"line 16, in GaussElim

tmp=A[maxRow][k]

IndexError: list index out of range"

我认为这意味着代码超出了索引的限制,但我不确定如何更正它。任何建议都将不胜感激谢谢!在def GaussElim(A):

n=len(A)

for i in range(0,n): #search for maximum in this column

maxE1=abs(A[i][i])

maxRow=i

for k in range(i+1,n):

if abs(A[k][i])>maxE1:

maxE1=abs(A[k][i])

maxRow=k

# swap maximum row with current row (column by column)

for k in range(i,n+1):

tmp=A[maxRow][k]

A[maxRow][k]=A[i][k]

A[i][k]=tmp

for k in range(i+1,n):

c=-A[k][i]/A[i][i]

for j in range(i,n+1):

if i==j:

A[k][j]=0

else:

A[k][j]+=c*A[i][j]

#solve equation Ax+b for an upper triangular matrix A

x=[0 for i in range(n)]

for i in range(n-1,-1,-1):

x[i]=A[i][n]/A[i][i]

for k in range(i-1,-1,-1):

A[k][n]-=A[k][i]*x[i]

return x

def main():

A=[[2,7,3,6,2],

[3,3,4,4,6],

[6,9,5,3,3],

[6,9,5,3,3],

[4,2,1,7,5]]

mysum1 = GaussElim(A)

print('a) GaussElimination Solution = {:.1f}'.format(mysum1))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值