用C语言求解N阶线性矩阵方程Ax=b的简单解法

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

用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列元素a jj=0 ,那此时不能再以a jj 为基元。

当变换到第j列时,从j行j列的元素a jj 以下的各元素中选取第一个不为0的元素,通过第三类初等行变换即交换两行将其交换到a jj 的位置上,然后再进行消元过程。交换系数矩阵中的两行,相当于两个方程的位置交换了。

再由高斯消元法,将第j列元素除a jj外第j行以下的其他元素通过第二种初等行变换化为0,这样,就能使系数矩阵通过这样的行变换化为一个上三角矩阵,即

当系数矩阵A进行初等行变换时,常数矩阵也要进行对应的初等行变换,即此

那么有

接下来,进行“反代”,由

可求出,再往上代入即可求

出以此类推,即可从x n推到x n-1,再推到x n-2直至x1。至此,未知矩阵x的所有元素就全部求出,即求出了原方程组有且仅有的唯一一组解。

基本原理示意图:

三、编写程序

1.#include

2.#include

3.#include

4.#define dim 10 //定义最大的维数10,为防止计算

值溢出

5.double a[dim+1][dim+1],b[dim+1],x[dim+1]; //定义双精度数组

6.double temp;

7.double getarray(int n); //定义输入矩阵元素的函数

8.double showarray(int n); //定义输出化简系数矩阵过程的函

9.int n,i,j,k,p,q;

10.double main()

11.{

12.

13.printf("请输入系数矩阵的阶数n(n<10):");

14.scanf("%d",&n);

15. /*判断矩阵阶数是否超过界定值*/

16. if(n>dim)

17. {

18. printf("错误:元数超过初设定的值%d,请重启程序重新输入\n",dim);

19. exit(0);

20. }

21.

22. /*输入系数矩阵和常数矩阵(即增广矩阵)的元素*/

23. getarray(n);

24.

25. /*使对角线上的主元素不为0*/

26. for(j=1;j<=n-1;j++)

27. {

28. if(a[j][j]==0)

29. for(i=j+1;i<=n;i++)

30. {

31. if(a[i][j]!=0)

32. {

33. /*交换增广矩阵的第i行与第j行的所有元素*/

34. for(k=1;k<=n;k++)

35. {

36. a[i][k]+=a[j][k];

37. a[j][k]=a[i][k]-a[j][k];

38. a[i][k]-=a[j][k];

39. }

40. b[i]+=b[j];

41. b[j]=b[i]-b[j];

42. b[i]-=b[j];

43. }

44. continue; //找到第j列第一个不为0的元素即跳回第一层循

45. }

46. }

47. /*开始用高斯简单迭代消元法进行求解计算*/

48. for(j=1;j<=n-1;j++)

49. {

50. /*使系数矩阵转化为上三角矩阵,常数矩阵相应进行变换*/

51. for(i=j+1;i<=n;i++)

52. {

53. temp=a[i][j]/a[j][j];

54. b[i]=b[i]-temp*b[j];

55. for(k=1;k<=n;k++)

56. a[i][k]=a[i][k]-temp*a[j][k];

57. printf("\n通过初等行变换增广矩阵矩阵C化为:\n");

58. /*输出进行初等行变换的过程*/

59. printf("C=");

60. for(p=1;p<=n;p++)

61. {

62. for(q=1;q<=n;q++)

63. printf("\t%.3f",a[p][q]);

64. printf("\t%.3f\n",b[p]);

相关文档
最新文档