《训练指南》——7.20

  基于我们在《Linear Algebra and Its Application》一书中对解线性方程组的高斯消元法的学习,这里给出线性方程组有唯一解的编程实现。

  参考代码如下:

 

typedef double Matrix[maxn][maxn];
//A[][]是增广矩阵,最终A[i][n]表示第i个变量的值
void gauss_elimination(Matrix A , int n)
{
     int i , j , k , r;

        for(i = 0;i < n;i++)//化成行阶梯型
        {
              r = i;
                for(j = i + 1;j < n;j++)//对第i行以下的行数消元的时候,把第i列非零的第r行数提到第i行
                     if(fabs(A[j][i]) > fabs(A[r][i]))  r= j;
                if(r != i)
                     for(j = 0;j <= n;j++)
                      swap(A[r][j],A[i][j]);

            for(k = i + 1;k < n;k++)//进行i+1~n行第i列的消元
            {
                  double f = A[k][i]/A[i][i];
                    for(j = i;j <= n;j++)  A[k][j] -= f * A[i][j];
            }
        }

        //基于行阶梯型,回代得到唯一的解向量
        for(i = n - 1;i >= 0;i--)
        {
               for(j = i+1;j < n;j++)
                  A[i][n] -= A[j][n] * A[i][j];
        A[i][n]  /=  A[i][i];
        }
}

 

posted on 2016-07-20 19:13  在苏州的城边  阅读(137)  评论(0编辑  收藏  举报

导航