用高斯消元法求解线性代数方程组.doc_第1页
用高斯消元法求解线性代数方程组.doc_第2页
用高斯消元法求解线性代数方程组.doc_第3页
用高斯消元法求解线性代数方程组.doc_第4页
用高斯消元法求解线性代数方程组.doc_第5页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

用高斯消元法求解线性代数方程组 (X*是方程组的精确解)1 高斯消去法1.1 基本思想及计算过程高斯(Gauss)消去法是解线性方程组最常用的方法之一,它的基本思想是通过逐步消元,把方程组化为系数矩阵为三角形矩阵的同解方程组,然后用回代法解此三角形方程组得原方程组的解。为便于叙述,先以一个三阶线性方程组为例来说明高斯消去法的基本思想。把方程(I)乘()后加到方程(II)上去,把方程(I)乘()后加到方程(III)上去,即可消去方程(II)、(III)中的x1,得同解方程组将方程(II)乘()后加于方程(III),得同解方程组:由回代公式(3.5)得x3 = 2,x2 = 8,x1 = -13。下面考察一般形式的线性方程组的解法,为叙述问题方便,将bi写成ai, n+1,i = 1, 2,n。 (1-1)如果a11 0,将第一个方程中x1的系数化为1,得其中, j = 1, , n + 1(记,i = 1, 2, , n; j = 1, 2, , n + 1)从其它n 1个方程中消x1,使它变成如下形式 (1-2)其中, 由方程(1-1)到(1-2)的过程中,元素起着重要的作用,特别地,把称为主元素。如果(1-2)中,则以为主元素,又可以把方程组(1-2)化为: (1-3)针对(1-3) 继续消元,重复同样的手段,第k步所要加工的方程组是:设,第k步先使上述方程组中第k个方程中xk的系数化为1:然后再从其它(n - k)个方程中消xk,消元公式为: (1-4)按照上述步骤进行n次后,将原方程组加工成下列形式:回代公式为: (1-5)综上所述,高斯消去法分为消元过程与回代过程,消元过程将所给方程组加工成上三角形方程组,再经回代过程求解。由于计算时不涉及xi, i = 1, 2, , n,所以在存贮时可将方程组AX = b,写成增广矩阵(A, b)存贮。下面,我们统计一下高斯消去法的工作量;在(1-4)第一个式子中,每执行一次需要次除法,在(1-5)第二个式子中,每执行一次需要次除法。因此在消元过程中,共需要次乘作法。此外,回代过程共有次乘法。汇总在一起,高斯消去法的计算量为:次乘除法。1.2 基于VC的C语言程序#include#define n 4 /*n为方程组系数矩阵的阶数*/int Gauss(float ann,float bn) int i,j,k,flag=1; float t; for(i=0;in-1;i+) if(aii=0) flag=0; break; else for(j=i+1;jn;j+) /*消元过程*/ t=-aji/aii; bj=bj+t*bi; for(k=i;kn;k+) ajk=ajk+t*aik; return(flag);void zg_matric(float ann,float bn) /*输出增广矩阵*/ int i,j; for(i=0;in;i+) for(j=0;j=0;i-) xi=bi; for(j=i+1;jn;j+) xi=xi-aij*xj; xi=xi/ai

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论