acwing883高斯消元

#include<bits/stdc++.h>
using namespace std;
 
const double eps=1e-6;
const int N=105;
 
int c,r,n,t,flag;
double a[N][N];
 
int guass(){
    for(c=0, r=0;c<n;c++){//c列 r行
        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;//最大是0
         
        for(int i=c;i<=n;i++) swap(a[r][i],a[t][i]);//将该行换到最上面
         
        for(int i=n;i>=c;i--) a[r][i]/=a[r][c];//将该行第一个数变成1
         
        for(int i=r+1;i<n;i++)//将下面所以行的第c列变成0
            if(fabs(a[i][c])>eps)
            for(int j=n;j>=r;j--)
                a[i][j]-=a[r][j]*a[i][c];
         
        r++;
    }
    if(r<n){//如果非完美阶梯型,即正方形矩阵的行还没遍历完
        for(int i=r;i<n;i++)//从r那行开始,即从为0=?的那行开始
            if(a[i][n]>eps) return -1;//0x=1,无解
        return 1;//0x=0,无穷多组解
    }
    else{//完美阶梯型
        for(int i=r-1;i>=0;i--)//转变成单位矩阵
            for(int j=i+1;j<r;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++)
            scanf("%lf",&a[i][j]);
    flag=guass();
    if(flag==0){
        for(int i=0;i<n;i++) printf("%.2lf\n",a[i][n]);
    }else if(flag==-1) puts("No solution");
    else puts("Infinite group solutions");
    return 0;
}

全部评论

相关推荐

学不完不睡觉11:一眼点评,不过,看运气吧
点赞 评论 收藏
分享
02-10 12:23
已编辑
新余学院 C++
采集想要offer:专业技能那里要一条一条的列出来吧,感觉你项目很厉害了,但是如果你不写技术栈面试官对你项目不太懂的话都没办法问你八股😂C++都是基架岗,都是一群9✌🏻在卷,我觉得你要是有时间学个go把MySQL和redis写上去找个开发岗吧
点赞 评论 收藏
分享
黑皮白袜臭脚体育生:简历条例统一按使用了什么技术实现了什么功能解决了问题或提升了什么性能指标来写会好些,如使用布隆过滤器实现了判断短链接是否存在,大大提升了查询速度
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务