码迷,mamicode.com
首页 > 其他好文 > 详细

高斯消元模板

时间:2014-07-22 00:27:38      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   io   for   re   

1.要求系数矩阵可逆

2.A为增广矩阵,即A[i][n]为第i个方程右边的bi

3.运行结束后A[i][n]即为第i个未知数的值

typedef double Matrix[N][N];

void gauss_elimination(Matrix A,int n)
{
    int i,j,k,r;
    for(i=0;i<n;i++)
    {
        //选一行r并与i行交换
        r = i;
        for(j=i+1;j<n;j++)
            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]);
        }
        //与第i+1~n行进行消元
        for(k=i+1;k<n;k++)
        {
            double f = A[k][i]/A[i][i];  //为了让A[k][i] = 0,第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];
    }
}

高斯消元模板,布布扣,bubuko.com

高斯消元模板

标签:style   blog   color   io   for   re   

原文地址:http://www.cnblogs.com/whatbeg/p/3858125.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!