博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
P3389 【模板】高斯消元法
阅读量:4332 次
发布时间:2019-06-06

本文共 1310 字,大约阅读时间需要 4 分钟。

首先,一个重要的概念:n个n元一次(不同)方程组可以解出唯一解

 

so 题意:给定一个线性方程组,对其求解(QAQ)

 

高斯消元:首先,把未知数放左边,常数放右边,然后提取系数放在矩阵里

     找到当前元的系数最大的式子放在i的位置(当前行)(主要是为了判断无解,放不放都行)

     i行当前元的系数化一(i行所有数/=当前元的系数)

     最后,对于每一行(除了i行)的数,减等于这一行当前元的系数乘上第i行对应位置系数

     那么,最后的矩阵

                 1   0   0    x

                 0   1   0    y

                 0   0   1.   z

 

见代码:

#include 
#define LL long longinline LL in() { LL x = 0, f = 1; char ch; while(!isdigit(ch = getchar()))(ch == '-') && (f = -f); while(isdigit(ch)) x = x * 10 + (ch ^ 48), ch = getchar(); return x * f;}const int maxn = 120;const double eps = 1e-5;double a[maxn][maxn];int n, m;int main() { m = (n = in()) + 1; for(int i = 1; i <= n; i++) for(int j = 1; j <= m; j++) scanf("%lf", &a[i][j]); for(int i = 1; i <= n; i++) { int pos = i; for(int j = i; j <= n; j++) if(fabs(a[j][i]) > fabs(a[pos][i])) pos = j; if(fabs(a[pos][i]) <= eps) return puts("No Solution"), 0; for(int j = i + 1; j <= m; j++) a[i][j] /= a[i][i]; a[i][i] = 1; for(int j = 1; j <= n; j++) { if(i == j) continue; double now = a[j][i]; for (int k = i; k <= m; k++) a[j][k] -= now * a[i][k]; } } for(int i = 1; i <= n; i++) printf("%.2f\n", a[i][m]); return 0;}

 

 

转载于:https://www.cnblogs.com/olinr/p/9479393.html

你可能感兴趣的文章
ffmpeg格式转换命令
查看>>
万方数据知识平台 TFHpple +Xpath解析
查看>>
Hive实现oracle的Minus函数
查看>>
秒杀多线程第四篇 一个经典的多线程同步问题
查看>>
RocketMQ配置
查看>>
vs code调试console程序报错--preLaunchTask“build”
查看>>
蚂蚁金服井贤栋:用技术联手金融机构,形成服务小微的生态合力
查看>>
端口号大全
查看>>
机器学习基石笔记2——在何时可以使用机器学习(2)
查看>>
POJ 3740 Easy Finding (DLX模板)
查看>>
MySQL 处理重复数据
查看>>
关于typedef的用法总结(转)
查看>>
【strtok()】——分割字符串
查看>>
Linux下安装rabbitmq
查看>>
曹德旺
查看>>
【转】判断点在多边形内(matlab)
查看>>
java基础之集合:List Set Map的概述以及使用场景
查看>>
Python 线程 进程 协程
查看>>
iOS语言中的KVO机制
查看>>
excel第一次打开报错 向程序发送命令时出错 多种解决办法含终极解决方法
查看>>