列主元高斯消元法求解线性方程组

#include<iostream>
#include<vector>
#include<cmath>
#include<algorithm>
using namespace std;
const int eps=1E-8;
typedef vector<double> vec;
typedef vector<vec> mat;
//求解Ax=b,A是方阵
//当方程组无解或者有无穷多解时,返回一个长度为0的数组
vec gauss_jordan(const mat& A,const vec& b)
{
    int n=A.size();
    mat B(n,vec(n+1));
    for(int i=0;i<n;i++)
        for(int j=0;j<n;j++)
            B[i][j]=A[i][j];
    //把b存放在A的右边方便一起处理
    for(int i=0;i<n;i++)
        B[i][n]=b[i];
    for(int i=0;i<n;i++)
    {
        //把正在处理的未知数系数的绝对值最大的式子换到第i行
        int pivot=i;
        for(int j=i;j<n;j++)
            if(abs(B[i][j])>abs(B[pivot][i]))
                pivot=i;
        swap(B[i],B[pivot]);
        if(abs(B[i][i])<eps)//无解或者有无穷多解
            return vec();
        for(int j=i+1;j<=n;j++)//把正在处理的未知数的系数变为1
            B[i][j]/=B[i][i];
        for(int j=0;j<n;j++)
        {
            if(i!=j)
            {
                //从第j个式子中消去第i个未知数
                for(int k=i+1;k<=n;k++)
                    B[j][k]-=B[j][i]*B[i][k];
            }
        }
    }
    vec x(n);
    for(int i=0;i<n;i++)//存放在右边的b就是答案
        x[i]=B[i][n];
    return x;
} 
int main()
{
    mat A;
    vec b;
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        A.push_back(b);
        for(int j=0;j<n;j++)
        {
            int x;
            cin>>x;
            A[i].push_back(x);
        }

    }
    for(int i=0;i<n;i++)
    {
        int x;
        cin>>x;
        b.push_back(x);
    }
    vec ans=gauss_jordan(A,b);
    for(int i=0;i<ans.size();i++)
        cout<<ans[i]<<" ";
    cout<<endl;
    return 0;
}
posted @ 2017-12-09 15:53  Zireael  阅读(1408)  评论(0编辑  收藏  举报