90分WA#1求助

P2455 [SDOI2006] 线性方程组

jy20091121 @ 2024-02-21 11:40:21

#include<bits/stdc++.h>
using namespace std;
const int eps=0.000001;
const int N=110;
int n;
double a[N][N];
int gauss()
{
    int c, r;
    for (c = 0, r = 0; c < n; c ++ )
    {
    int t = r;
    for (int i = r; i < n; i ++ )   // 找到绝对值最大的行
    if (fabs(a[i][c]) > fabs(a[t][c]))
    t = i;
    if (fabs(a[t][c]) < eps) continue;
    for (int i = c; i <= n; i ++ ) swap(a[t][i], a[r][i]); 
    for (int i = n; i >= c; i -- ) a[r][i] /= a[r][c];      
    for (int i = r + 1; i < n; i ++ ) 
    if (fabs(a[i][c]) > eps)
    for (int j = n; j >= c; j -- )
    a[i][j] -= a[r][j] * a[i][c];
    r++ ;
    }

    if (r < n)
    {
        for (int i = r; i < n; i ++ )
            if (fabs(a[i][n]) > eps)
                return 2;
        return 1;
    }
    for (int i = n - 1; i >= 0; i -- )
        for (int j = i + 1; j < n; j ++ )
            a[i][n] -= a[i][j] * a[j][n];
    return 0;
}
int main(){
    cin>>n;
    for(int i=0;i<n;i++){
        for(int j=0;j<=n;j++) cin>>a[i][j];
    }
    int t=gauss();
    if(t==0){
        for(int i=0;i<n;i++){
        printf("%.2lf\n",a[i][n]);  
        }
    }
    else{
        cout<<"No Solution";
    }
}

|