#include<iostream>
#include<cstdio>
#include<iomanip>
using namespace std;
#define e 0.00000001
#define maxn 50 int n;//规模nXn
double a[maxn][maxn];//系数矩阵
double b[maxn];//b矩阵
double m[maxn][maxn];//中间变量矩阵
double x[maxn];//最终解
int H=;//扩大H被结算(优化)
/*
读取数据
*/
void read(){
cout<<"请输入系数矩阵规模n:= ";
cin>>n;
cout<<"|-----------------------------\n";
cout<<"|请输入系数矩阵,如:\n";
cout<<"|1.1348 3.8326 1.1651 3.4017\n";
cout<<"|0.5301 1.7875 2.5330 1.5435\n";
cout<<"|3.4129 4.9317 8.7643 1.3142\n";
cout<<"|1.2371 4.9998 10.6721 0.0147\n";
cout<<"|-----------------------------\n";
for(int i=;i<=n;i++)
for(int j=;j<=n;j++){
cin>>a[i][j];
a[i][j]*=H;
}
cout<<"|-----------------------------\n";
cout<<"|请输入b矩阵,如:\n";
cout<<"|9.5342 6.3941 18.4231 16.9237\n";
cout<<"|-----------------------------\n";
for(int i=;i<=n;i++){
cin>>b[i];
b[i]*=H;
}
} /*
中间矩阵输出
参数:消元次数
*/
void PrintProc(int cases){
printf("--------第%d次消元结果如下:\n",cases);
for(int i=;i<=n;i++){
for(int j=;j<=n;j++){
cout<<setw()<<a[i][j]<<' ';
}
cout<<setw()<<b[i]<<'\n';
}
cout<<"END THIS SHOW-------------\n";
} /*
显示结果
*/
void Print(){
cout<<"|-----------------------------\n";
cout<<"|结果为:\n";
for(int i=;i<=n;i++){
printf("x[%d]= %lf\n",i,x[i]);
}
cout<<"|-----------------------------\n\n";
} /*
顺序消元法
*/
void ShunXuXiaoYuan(){
//消元计算
for(int k=;k<n;k++){
for(int i=k+;i<=n;i++){
m[i][k]=a[i][k]/a[k][k];
for(int j=k+;j<=n;j++){
a[i][j]-=m[i][k]*a[k][j];
}
}
for(int i=k+;i<=n;i++){
b[i]-=m[i][k]*b[k];
}
PrintProc(k);//输出中间计算过程
}
//回代求解
x[n]=b[n]/a[n][n];
for(int i=n-;i>;i--){
x[i]=b[i];
for(int j=i+;j<=n;j++)
x[i]-=a[i][j]*x[j];
x[i]/=a[i][i];
}
//输出结果
Print();
} /*
列主消元
*/
void LieZhuXiaoYuan(){
for(int k=;k<n;k++){
//选主元[这一列的绝对值最大值]
double ab_max=-;
int max_ik;
for(int i=k;i<=n;i++){
if(abs(a[i][k])>ab_max){
ab_max=abs(a[i][k]);
max_ik=i;
}
}
//交换行处理[先判断是否为0矩阵]
if(ab_max<e){//0矩阵情况
cout<<"det A=0\n";
break;
}else if(max_ik!=k){//是否是当前行,不是交换
double temp;
for(int j=;j<=n;j++){
temp=a[max_ik][j];
a[max_ik][j]=a[k][j];
a[k][j]=temp;
}
temp=b[max_ik];
b[max_ik]=b[k];
b[k]=temp;
}
//消元计算
for(int i=k+;i<=n;i++){
a[i][k]/=a[k][k];
for(int j=k+;j<=n;j++){
a[i][j]-=a[i][k]*a[k][j];
}
b[i]-=a[i][k]*b[k];
}
PrintProc(k);//输出中间计算过程
if(k<n-)continue;
else{
if(abs(a[n][n])<e){
cout<<"det A=0\n";
break;
}else{//回代求解
x[n]=b[n]/a[n][n];
for(int i=n-;i>;i--){
x[i]=b[i];
for(int j=i+;j<=n;j++)
x[i]-=a[i][j]*x[j];
x[i]/=a[i][i];
}
//输出结果
Print();
}
}
}
} /*
主函数
*/
int main(){
while(){
read();
LieZhuXiaoYuan();
//ShunXuXiaoYuan();
}return ;
}
/*
书上高斯消元的例子:
1 1 1
1 3 -2
2 -2 1 6 1 1
*/
/*
书上列主消元的例子:
-0.002 2 2
1 0.78125 0
3.996 5.5625 4 0.4 1.3816 7.4178
*/

[算法] 高斯消元法 列主消元法 C++ 代码的更多相关文章

  1. javascript数据结构与算法--散列

    一:javascript数据结构与算法--散列  一:什么是哈希表? 哈希表也叫散列表,是根据关键码值(key,value)而直接进行访问的数据结构,它是通过键码值映射到表中一个位置来访问记录的,散列 ...

  2. 基本算法思想Java实现的详细代码

    基本算法思想Java实现的详细代码 算法是一个程序的灵魂,一个好的算法往往可以化繁为简,高效的求解问题.在程序设计中算法是独立于语言的,无论使用哪一种语言都可以使用这些算法,本文笔者将以Java语言为 ...

  3. C++算法之大数加法计算的代码

    如下代码段是关于C++算法之大数加法计算的代码,希望对大家有用. { int length; int index; int smaller; int prefix = 0; if(NULL == sr ...

  4. jeecg 主-附表生成代码例子

    jeecg 主-附表生成代码例子 - CSDN博客https://blog.csdn.net/u010411264/article/details/51243277 JEECG Online Codi ...

  5. JavaScript数据结构与算法-散列练习

    散列的实现 // 散列类 - 线性探测法 function HashTable () { this.table = new Array(137); this.values = []; this.sim ...

  6. 【优化算法】Greedy Randomized Adaptive Search算法 超详细解析,附代码实现TSP问题求解

    01 概述 Greedy Randomized Adaptive Search,贪婪随机自适应搜索(GRAS),是组合优化问题中的多起点元启发式算法,在算法的每次迭代中,主要由两个阶段组成:构造(co ...

  7. 《算法导论》第二章demo代码实现(Java版)

    <算法导论>第二章demo代码实现(Java版) 前言 表示晚上心里有些不宁静,所以就写一篇博客,来缓缓.囧 拜读<算法导论>这样的神作,当然要做一些练习啦.除了练习题与思考题 ...

  8. Gauss列主消元

    问题:1.列主消元为什么精度高? 2.fabs函数精确度 #include<iostream> #include<cstdio> #include<cstring> ...

  9. 数据结构和算法(Golang实现)(10)基础知识-算法复杂度主方法

    算法复杂度主方法 有时候,我们要评估一个算法的复杂度,但是算法被分散为几个递归的子问题,这样评估起来很难,有一个数学公式可以很快地评估出来. 一.复杂度主方法 主方法,也可以叫主定理.对于那些用分治法 ...

随机推荐

  1. Asp.Net 获取FileUpload控件的文件路径、文件名、扩展名

    string fileNameNo = Path.GetFileName(FileUploadImg.PostedFile.FileName); //获取文件名和扩展名string Directory ...

  2. 使用虚拟机win7系统遇到问题及解决

    安装VMware并在其中安装win7专业版系统,这里不再赘述.因为...我就是照着百度来的.哈哈 说说使用中遇到的问题. 本来安装成功后,可以很愉快的运行着.后来莫名奇妙的出现了两个问题:1.虚拟机运 ...

  3. javascript 命令方式 测试例子

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. NLPP-03-Exercises

    <PYTHON自然语言处理>第3章 处理原始文本 更多更复杂有关处理HTML内容 http://www.crummy.com/software/BeautifulSoup/ 3.11 深入 ...

  5. POJ 2155 Matrix (二维树状数组)

    Matrix Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 17224   Accepted: 6460 Descripti ...

  6. 《机器学习实战》学习笔记——第14章 利用SVD简化数据

    一. SVD 1. 基本概念: (1)定义:提取信息的方法:奇异值分解Singular Value Decomposition(SVD) (2)优点:简化数据, 去除噪声,提高算法的结果 (3)缺点: ...

  7. linux各种命令

    命令  [选项]  [参数] read  -t  30    -p   "Please input a num: "   num 功能:将键盘输入的数赋予num ps   aux  ...

  8. subprocess添加超时功能

    def TIMEOUT_COMMAND(command, timeout): """call shell-command and either return its ou ...

  9. 【笔记】CAP原理和BASE思想

    摘自http://www.jdon.com/37625 分布式领域CAP理论,Consistency(一致性), 数据一致更新,所有数据变动都是同步的Availability(可用性), 好的响应性能 ...

  10. Android的Activity屏幕切换动画-左右滑动切换

    . --> 在Android开发过程中,经常会碰到Activity之间的切换效果的问题,下面介绍一下如何实现左右滑动的切换效果,首先了解一下Activity切换的实现,从Android2.0开始 ...