- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
参考资料:/forum.php?mod=viewthreadtid=55extra=page%3D1分享百分百,最纯粹的分享平台用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的所有元素就全部求出,即求出了原方程组有且仅有的唯一一组解。基本原理示意图:三、编写程序#includestdio.h#includestdlib.h#includemath.h#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);? ?? ?? ?? ?? ?? ???//定义输出化简系数矩阵过程的函数int n,i,j,k,p,q;double main(){? ?printf(请输入系数矩阵的阶数n(n10):);scanf(%d,n);? ? /*判断矩阵阶数是否超过界定值*/? ? if(ndim)? ? {? ?? ???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];
您可能关注的文档
- 序言与基础知识.PPT
- 信息检索第四次课课件.ppt
- 旭阳雷迪第二次上机题目.doc
- 絮凝池搅拌机的设计及其工艺流程.doc
- 选课系统.doc
- 学分制成绩管理系统的设计与实现.doc
- 学科建设系统(SQL).doc
- 学年论文格式.doc
- 学生档案毕业设计.doc
- 学生档案管理.doc
- 2025年安徽省巢湖市辅警招聘考试试题题库及答案详解(精选题).docx
- 小学四年级语文上册期中测试卷(人教版).docx
- (网络收集版)2025年高考全国一卷数学高考真题文档版.docx
- 2025年浙江省龙泉市辅警招聘考试试题题库及一套参考答案详解.docx
- 基于SFIC修正模型的兰州市网约车协同治理问题研究.docx
- (网络收集版)2025年高考生物真题文档版(无答案)适用地区辽宁、黑龙江、吉林、内蒙古.docx
- 节点特征增强的信息溯源关键技术研究.docx
- 2025年辅警招聘考试真题及完整答案详解1套.docx
- 2025年河南省辅警招聘考试考试试题库及答案详解(网校专用).docx
- 《人体具有免疫功能》(教案及反思)-2024-2025学年济南版(2024)初中生物八年级上册.docx
最近下载
- 露天矿采矿与剥离作业规程.pdf VIP
- 电大国家开放大学《政府经济学》(本)2025-2026期末试题及答案2025.pdf VIP
- 第27课 定速巡航的控制 教案 义务教育人教版信息科技六年级全一册.docx VIP
- 幼儿园美术教案《沙漠里的树》植树节主题活动PPT课件.doc VIP
- Java基础知识大全单选题100道及答案.docx VIP
- 工匠精神精品课件.pptx
- 25《带上她的眼睛》课件(共45张PPT).pptx
- 上海海事大学2021-2022年《货币银行学》期末考试试卷(A卷)含参考答案.docx
- 2024年福建省中考化学真题试卷(含答案).docx VIP
- 风电场并网测试方案.docx
文档评论(0)