Python高斯消去求线性方程的解

#Python高斯消去求线性方程的解

'''
高斯消去法
通过消元过程把一般方程组化成三角方程组
再通过回代过程求出方程组的解
'''
def GaussianElimination(A,B):
    N = len(A)
    for i in range(1,N):
        for j in range(i,N):
            # 计算消元因子delta
            delta = A[j][i-1]/A[i-1][i-1]
            # 从第i-1行开始消元
            for k in range(i-1,N):
                # 对A进行消元
                A[j][k] = A[j][k] - A[i-1][k]*delta
            # 对B进行消元
            B[j] = B[j]-B[i-1]*delta
    # 进行回代,直接将方程的解保留在B中
    B[N-1] = B[N-1]/A[N-1][N-1]
    for i in range(N-2,-1,-1):
        for j in range(N-1,i,-1):
            B[i] = B[i]- A[i][j]*B[j]
        B[i] = B[i]/A[i][i]
    # 返回所有解的列表
    return B

matrixA = [[1,3,3],[-2,3,-5],[2,5,6]]
matrixB = [4,0,1]
print('方程的解为',GaussianElimination(matrixA, matrixB))

输出的结果:

方程的解为 [148.0, 7.0, -55.0]
  • 10
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值