用C语言求解N阶线性矩阵方程Axb简单解法

用C语言求解N阶线性矩阵方程Ax=b的简单解法一、描述问题:题目:求解线性方程组Ax=b,写成函数。其中,A为n×n的N阶矩阵,x为需要求解的n元未知数组成的未知矩阵,b为n个常数组成的常数矩阵。即运行程序时的具体实例为:转化为矩阵形式(为检验程序的可靠性,特意选取初对角线元素为0的矩阵方程组)即为:二、分析问题并找出解决问题的步骤:由高等代数知识可知,解高阶线性方程组有逆矩阵求解法、增广矩阵求解法等,而在计算机C语言中,有高斯列主消元法、LU分解法、雅克比迭代法等解法。为了与所学的高等代数知识相一致,选择使用“高斯简单迭代消元法”,与高等代数中的“增广矩阵求解法”相一致。以下简述高斯消元法的原理:算法基本原理:首先,为了能够求解N阶线性方程组(N由用户输入),所以需要定义一个大于N维的数组a[dim+1][dim+1](dim为设定的最大维数,防止计算量溢出),当用户输入的阶数N超过设定值时提示重启程序重新输入。进而,要判断方程组是否有解,无解提示重启程序重新输入,有解的话要判断是有无数不定解还是只有唯一一组解,在计算中,只有当原方程组有且只有一组解时算法才有意义,而运用高等代数的知识,只有当系数矩阵对应的行列式 |A|≠0 时,原方程组才有唯一解,所以输入系数矩阵后要计算该系数矩阵的行列式 |A|(定义了getresult(n)函数计算),当行列式 |A|=0 时同样应提示重启程序重新输入, |A|≠0 时原方程组必然有且仅有唯一一组解。判断出方程组有且仅有唯一一组解后,开始将系数矩阵和常数矩阵(合并即为增广矩阵)进行初等行变换(以?a11?为基元开始,将第j列上j行以下的所有元素化为0),使系数矩阵转化为上三角矩阵。这里要考虑到一种特殊情况,即交换到第j-1列后,第j行第j列元素?ajj=0?,那此时不能再以?ajj?为基元。当变换到第j列时,从j行j列的元素?ajj?以下的各元素中选取第一个不为0的元素,通过第三类初等行变换即交换两行将其交换到?ajj?的位置上,然后再进行消元过程。交换系数矩阵中的两行,相当于两个方程的位置交换了。再由高斯消元法,将第j列元素除?ajj?外第j行以下的其他元素通过第二种初等行变换化为0,这样,就能使系数矩阵通过这样的行变换化为一个上三角矩阵,即,当系数矩阵A进行初等行变换时,常数矩阵也要进行对应的初等行变换,即此时?那么有接下来,进行“反代”,由?可求出??,再往上代入??即可求出??以此类推,即可从?xn推到?xn-1?,再推到xn-2?直至?x1?。至此,未知矩阵x的所有元素就全部求出,即求出了原方程组有且仅有的唯一一组解。基本原理示意图:三、编写程序#include#include#include#define dim 10? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?//定义最大的维数10,为防止计算值溢出double a[dim+1][dim+1],b[dim+1],x[dim+1];? ?//定义双精度数组double temp;double getarray(int n);? ?? ?? ?? ?? ?? ?? ?//定义输入矩阵元素的函数double showarray(int n);? ?? ?? ?? ?? ?? ???//定义输出化简系数矩阵过程的函数intn,i,j,k,p,q;double main(){? ?printf("请输入系数矩阵的阶数n(n<10):");scanf("%d",&n);? ? /*判断矩阵阶数是否超过界定值*/? ? if(n>dim)? ? {? ?? ???printf("错误:元数超过初设定的值%d,请重启程序重新输入\n",dim);? ?? ???exit(0);? ? }? ? /*输入系数矩阵和常数矩阵(即增广矩阵)的元素*/? ? getarray(n);? ??? ? /*使对角线上的主元素不为0*/? ? for(j=1;j<=n-1;j++)? ? {? ?? ???if(a[j][j]==0)? ?? ?? ?? ?for(i=j+1;i<=n;i++)? ?? ?? ?? ?{? ?? ?? ?? ?? ? if(a[i][j]!=0)? ?? ?? ?? ?? ? {? ?? ?? ?? ?? ?? ???/*交换增广矩阵的第i行与第j行的所有元素*/? ?? ?? ?? ?? ?? ???for(k=1;k<=n;k++)? ?? ?? ?? ?? ?? ???{? ?? ?? ?? ?? ?? ?? ?? ?a[i][k]+=a[j][k];? ?? ?? ?? ?? ?? ?? ?? ?a[j][k]=a[i][k]-a[j][k]

用c语言求解n阶线性矩阵方程组,用C语言求解N阶线性矩阵方程Axb简单解法.docx相关推荐

  1. 用c语言求解n阶线性矩阵方程组,用C语言求解N阶线性矩阵方程Ax=b的简单解法

    首先,为了能够求解N阶线性方程组(N由用户输入),所以需要定义一个大于N维的数组a[dim+1][dim+1](dim为设定的最大维数,防止计算量溢出),当用户输入的阶数N超过设定值时提示重启程序重新 ...

  2. 用c语言求解n阶线性,用C语言求解N阶线性矩阵方程Ax=b的简单解法.docx

    您所在位置:网站首页 > 海量文档 &nbsp>&nbsp高等教育&nbsp>&nbsp专业基础教材 用C语言求解N阶线性矩阵方程Ax=b的简单解法. ...

  3. 两个随机矩阵相乘的c语言编程,实现两个矩阵相乘的C语言程序

    程序功能:实现两个矩阵相乘的C语言程序,并将其输出 代码如下: 1 #include "stdafx.h" 2 #include "windows.h" 3 v ...

  4. c语言编写加法程序代码,矩阵加法 (C语言代码)

    解题思路: 注意事项:输出数与数之间只有一个空格. 参考代码: #include void main() { int a,b,c,d,e; int ask1[100][100]={0}; int as ...

  5. 《鲁棒控制——线性矩阵不等式处理方法》(俞立)第二、三、四章学习笔记

    第二章   线性矩阵不等式  :非零向量,  或者的最大特征值小于0. 是凸集.(设V是数域P上的线性空间,W是V的一个非空子集,如果对W中任意两个向量a,b以及任意0<=c<=1,都有c ...

  6. c语言从键盘输入5阶方阵,输入5×5阶的矩阵,编程实现: (1)求两条对角线上的各元素之和....

    编程实现:输入一个英文句子,将句子中每个单词的首字母大写后输出. #includevoidmain(){charx[100];inti;printf("请输入英语句子\n");ge ...

  7. n阶魔方的构成方法C语言,穷举法打印n阶魔方矩阵

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 //   穷举法打印n阶魔方矩阵 n <= 10 #include #include int A[ 11 ][ 11 ]; bool Flag[ 1 ...

  8. 用c语言验证5阶魔方矩阵,穷举法打印n阶魔方矩阵

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 //   穷举法打印n阶魔方矩阵 n <= 10 #include #include int A[ 11 ][ 11 ]; bool Flag[ 1 ...

  9. C语言数据结构(大话数据结构——笔记1)数据结构绪论、算法、线性表

    [C语言描述]<数据结构和算法> 说是这个教程是按照<大话数据结构>这本书来编写的:数据结构与算法经典书籍--大话数据结构(带配套源码) ↑废话太TM多了,换一个! [搞定数据 ...

最新文章

  1. 关于C#开发山寨操作系统,程序语言,浏览器,IDE,Office,Photoshop等大型程序的可行性歪论及意义...
  2. php实现单选和多选功能,input:checkbox多选框实现单选效果跟radio一样
  3. Jupyter notebook与Spyder,以及Jupyter notebook与Spyder集成插件
  4. linux内核匹配的编译器gcc,linux下正则匹配的C实现
  5. Re题目------Enm.exe
  6. Android两个tab吸顶,Android scrollView和viewpager嵌套 指示器吸顶 根据viewpager每
  7. 前端学习(1854)vue之电商管理系统电商系统之安装mysql
  8. 分布式锁 动态代理 Java数据结构List,Set,Map,Spring执行流程,Spring MVC组件
  9. springMVC接收数据和响应返回
  10. centos7下安装mysql及测试centos_CentOS7安装mysql8
  11. python类介绍_Python基础介绍 | Class类
  12. 2018服务器 芯片组,2018最新主板知识详解,详谈DIY(主板篇)
  13. 代码整洁之道读书笔记----第三章---函数--第一节-专注且短小
  14. 国际结算习题集及答案
  15. 揭秘本周聪明钱|主力资金集中追捧“券业新一哥”;融资客不惧利空潜入这只股!
  16. matlab怎设置静态变量,Matlab/Simulink中的静态变量和全局变量
  17. 2022全新车型汽车配置参数数据库大全
  18. 第三次个人作业——关于K米(Andorid)的案例分析
  19. 【jvm】8-垃圾回收
  20. 如何鉴别真假苹果原装20W快充头

热门文章

  1. 电脑word在哪_新的电脑应该安装哪些软件?只需这9个足够你用一生!
  2. mysql 创建外键实例_mysql 外键创建实例
  3. 光盘刻录只允许读取不能拷贝_便携易用,读写强劲:ORICO外置刻录光驱体验
  4. mysql命令导入存储过程报错_mysql导入存储过程时declare报错的有关问题解决
  5. react 合并数组_React快速上手
  6. 图片压缩大小java_压缩图片大小(Java源码)
  7. python金融工程的工具包_金融工程及其Python应用
  8. pytorch 不同设备下保存和加载模型,需要指定设备
  9. 行星轨迹制作_FLASH做的八大行星的轨道图的教学
  10. amba simple class驱动_学习笔记:class加载器和双亲委派模型