这是个版子题,当然本蒟蒻也是看了好几天才明白

对于这样的线性方程组,我们可以看成是一个矩阵

对于百度百科给的定义(我感到很迷)赶脚和行列式有的一拼

但我们要注意的是:

行列式是一个确切的值(有关行列式求值,下片博文再说),可以看做是一个数值;

而矩阵不同,矩阵是一个数表,无特殊的值。当然,性质也略有不同(这里就先不细讲了)

高斯消元的核心就是把这个n*n的矩阵消成一个对角矩阵(就是除了a【i】【i】为1以外,其余全为零但是不要乱划a【i】【n+1】这是我们要输出的东西)然后就ok了

其中一些性质可以通过度娘或下面的(李昊的)过程代码验证一下

//这不是AC代码,只是一个检测的(黈力的小心一点啊QAQ)
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<cstdlib>
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair<int,int> pr;
const double pi=acos(-);
#define rep(i,a,n) for(int i=a;i<=n;i++)
#define per(i,n,a) for(int i=n;i>=a;i--)
#define Rep(i,u) for(int i=head[u];i;i=Next[i])
#define clr(a) memset(a,0,sizeof a)
#define pb push_back
#define mp make_pair
#define fi first
#define sc second
ld eps=1e-;
ll pp=;
ll mo(ll a,ll pp){if(a>= && a<pp)return a;a%=pp;if(a<)a+=pp;return a;}
ll powmod(ll a,ll b,ll pp){ll ans=;for(;b;b>>=,a=mo(a*a,pp))if(b&)ans=mo(ans*a,pp);return ans;}
ll read(){
ll ans=;
char last=' ',ch=getchar();
while(ch<'' || ch>'')last=ch,ch=getchar();
while(ch>='' && ch<='')ans=ans*+ch-'',ch=getchar();
if(last=='-')ans=-ans;
return ans;
}
//head
int n,m;
double a[][]; bool check(int k){
if(fabs(a[k][n+])<eps)return ;
rep(i,,n)
if(fabs(a[k][i])>eps)return ;
return ;
}
int main(){
freopen("1.txt","r",stdin);
n=read();m=read();
// a_i,1 a_i,2 ... a_i,n a_i,n+1
rep(i,,m)
rep(j,,n+)a[i][j]=read();
rep(j,,m){
rep(k,,n+)cout<<a[j][k]<<" ";
puts("");
}
int flag=;
rep(i,,n){
int t=i;
while(a[t][i]== && t<=n)t+=;
if(t==n+){
flag=;
continue;
}
rep(j,,n+)swap(a[i][j],a[t][j]);
double kk=a[i][i];
rep(j,,n+)a[i][j]/=kk;
rep(j,,m)
if(i!=j){
double kk=a[j][i];
rep(k,,n+)
a[j][k]-=kk*a[i][k];
}
puts("------------");
rep(j,,m){
rep(k,,n+)cout<<a[j][k]<<" ";
puts("");
}
}
if(flag){
rep(i,,m)
if(!check(i)){
printf("No solution\n");
return ;
}
printf("So many solutions\n");
} }

通过这个代码,可以看到化简的每一步过程

下面才是真正的AC代码:

//真正的AC代码
#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
int n,s;
double a[][];
int main()
{
cin>>n;
for(int i=;i<=n;i++)//输入矩阵
for(int j=;j<=n+;j++)//别忘记最后那一列
  cin>>a[i][j];
for(int i=;i<=n;i++)
{
s=i;
while(a[s][i]==&&s<=n)
s++;
if(s==n+)
{
cout<<"No Solution";//判是否有解(若有一行或一列全为0,则无解)
return ;
}
for(int j=;j<=n+;j++)
swap(a[i][j],a[s][j]);
double k=a[i][i];
for(int j=;j<=n+;j++)
a[i][j]=a[i][j]/k; //为防止a【i】【i】为零,可以换一下
for(int j=;j<=n;j++)
{
if(i!=j)
{
double ki=a[j][i];
for(int m=;m<=n+;m++)
a[j][m]=a[j][m]-ki*a[i][m];//这就保证可以将除了a【i】【i】的全部为0
}
}
}
for(int i=;i<=n;i++)
printf("%.2lf\n",a[i][n+]);//输出ouo
return ;
}

这其中用到了一些神奇的性质,还是提前掌握为妙

【洛谷P3389 【模板】高斯消元法】的更多相关文章

  1. 洛谷P3373 [模板]线段树 2(区间增减.乘 区间求和)

    To 洛谷.3373 [模板]线段树2 题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某区间每一个数加上x 2.将某区间每一个数乘上x 3.求出某区间每一个数的和 输入输出格式 输入格 ...

  2. 洛谷P3375 [模板]KMP字符串匹配

    To 洛谷.3375 KMP字符串匹配 题目描述 如题,给出两个字符串s1和s2,其中s2为s1的子串,求出s2在s1中所有出现的位置. 为了减少骗分的情况,接下来还要输出子串的前缀数组next.如果 ...

  3. LCT总结——概念篇+洛谷P3690[模板]Link Cut Tree(动态树)(LCT,Splay)

    为了优化体验(其实是强迫症),蒟蒻把总结拆成了两篇,方便不同学习阶段的Dalao们切换. LCT总结--应用篇戳这里 概念.性质简述 首先介绍一下链剖分的概念(感谢laofu的讲课) 链剖分,是指一类 ...

  4. 【AC自动机】洛谷三道模板题

    [题目链接] https://www.luogu.org/problem/P3808 [题意] 给定n个模式串和1个文本串,求有多少个模式串在文本串里出现过. [题解] 不再介绍基础知识了,就是裸的模 ...

  5. 洛谷-P5357-【模板】AC自动机(二次加强版)

    题目传送门 -------------------------------------- 过年在家无聊补一下这周做的几道AC自动机的模板题 sol:AC自动机,还是要解决跳fail边产生的重复访问,但 ...

  6. 洛谷.1919.[模板]A*B Problem升级版(FFT)

    题目链接:洛谷.BZOJ2179 //将乘数拆成 a0*10^n + a1*10^(n-1) + ... + a_n-1的形式 //可以发现多项式乘法就模拟了竖式乘法 所以用FFT即可 注意处理进位 ...

  7. 洛谷.3803.[模板]多项式乘法(FFT)

    题目链接:洛谷.LOJ. FFT相关:快速傅里叶变换(FFT)详解.FFT总结.从多项式乘法到快速傅里叶变换. 5.4 又看了一遍,这个也不错. 2019.3.7 叕看了一遍,推荐这个. #inclu ...

  8. 洛谷.3803.[模板]多项式乘法(NTT)

    题目链接:洛谷.LOJ. 为什么和那些差那么多啊.. 在这里记一下原根 Definition 阶 若\(a,p\)互质,且\(p>1\),我们称使\(a^n\equiv 1\ (mod\ p)\ ...

  9. 洛谷P3385 [模板]负环 [SPFA]

    题目传送门 题目描述 暴力枚举/SPFA/Bellman-ford/奇怪的贪心/超神搜索 输入输出格式 输入格式: 第一行一个正整数T表示数据组数,对于每组数据: 第一行两个正整数N M,表示图有N个 ...

  10. [洛谷P3806] [模板] 点分治1

    洛谷 P3806 传送门 这个点分治都不用减掉子树里的了,直接搞就行了. 注意第63行 if(qu[k]>=buf[j]) 不能不写,也不能写成>. 因为这个WA了半天...... 如果m ...

随机推荐

  1. Edge BUG欣赏之四摸鸡与IP地址的恩怨

    <html><head>     <meta http-equiv="Content-Type" content="text/html; c ...

  2. (四)版本控制管理器之VSS

    在上一篇<(二)版本控制管理器值CVS(下)>的文章中,我为大家介绍了CVS这个版本控制器,接下来我继续跟大家分享介绍下一个版本控制管理器--VSS,为什么要说这个版本控制器呢?早已过时的 ...

  3. 【公众号系列】SAP HANA 平台的优势

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[公众号系列]SAP HANA 平台的优势   ...

  4. Asp.net mvc 项目返回Json

    因mvc控制器返回类型JsonResult 在处理对象转JSON的时候,对日期的格式化处理并不太符合要求,所以重新继承抽象类ActionResult使用Newtonsoft.Json来系列化 usin ...

  5. 有两个表A和B,均有key和value两个字段,如果B的key在A中也有,就把B的value替换为A中对应的value

    update B b set b.value=(select max(a.value) from A a where b.key=a.key) from A c where b.key=c.key) ...

  6. Markdown语法指南

    1.背景 个人比较喜欢用Markdonw写东西,比如写博客随笔,写有道云笔记等,但有的时候会突然忘记某个具体语法怎么写了,如插入图片.插入链接.表格等,那干脆把这个语法简单地总结一下,也方便日后快速查 ...

  7. Springboot配置文件解析器

    @EnableScheduling @MapperScan(value = "com.****.dao") @EnableTransactionManagement @Enable ...

  8. vue 应用生产环境的 webpack 打包配置优化

    转:https://blog.csdn.net/robin_star_/article/details/83856363 前言:很好的打包优化的帖子,还没来的急去实测验证 1. 去掉 console ...

  9. 两台主机,ssh端口不同,如何拷贝文件

    A主机ip:172.26.225.199 ssh端口12995 B主机ip:172.26.225.200 ssh端口12991 将B主机的文件拷贝到A主机 [root@test2019030517 s ...

  10. 【Topcoder 1643】PossibleOrders

    题意:给一些等价关系,问把所有的数按照大小排序的种类数. 思路:首先并查集维护等价类,然后设有\(n\)个等价类. 那么就可以\(dp\)了. 考虑\(dp(i)\)表示还剩下\(i\)个等价类,答案 ...