利用初等行变换求矩阵的逆运算的代码
3页1、/*reverse matrix*/利用的是AX=B,X=AB,这里B=E;进行初等行变换求解,把左边化为单位阵,右边就是A矩阵的逆矩阵;void swap(double *a,int i,int line,int n) / exchange line/交换行位置,i控制行号,line也是行号,/n是矩阵列数int j;double temp;for(j=0;jn;j+)temp=ai*n+j;ai*n+j=aline*n+j;aline*n+j=temp;void calculate(double *p,double *q,int n) /形成上三角阵int i,j,k,m,line;double max,temp,mmul;for(i=0;in;i+)max=fabs(pi*n+i);temp=pi*n+i;line=i;for(j=i+1;jmax)max=fabs(pj*n+i); temp=pj*n+i; line=j; if(max=1e-5) printf(no inverse arrayn);return;if(line!=i) swap(p,i,line,n);/将每
2、一列中最大行换到i行swap(q,i,line,n);for(k=0;kn;k+)pi*n+k/=temp;/将i行的每个数都除以i行i列的值,将i行i列化为1qi*n+k/=temp;for(k=i+1;kn;k+)/将i列i行下面其它行的值都化为0mmul=pk*n+i;for(m=0;m0;i-)for(j=i-1;j=0;j-)/从下往上每一行进行计算,与前面相反mmul=pj*n+i;pj*n+i-=pi*n+i*mmul;for(k=0;kn;k+)qj*n+k-=qi*n+k*mmul;void unitmatrix(double *q,int n) /形成单位矩阵,矩阵q是一个单位阵int i,j;for(i=0;in;i+)for(j=0;jn;j+)if(i=j)qi*n+j=1;elseqi*n+j=0;void MatrixInverse(double *A,double *C,int n)/矩阵求逆,A为要求的矩阵,C为求得的逆矩阵unitmatrix(C,n);/将C初始化为单位阵 calculate(A,C,n);/将A化为了上三角阵 backcalculate(A,C,n); /将A化为了单位阵,这时C即为所求
《利用初等行变换求矩阵的逆运算的代码》由会员re****.1分享,可在线阅读,更多相关《利用初等行变换求矩阵的逆运算的代码》请在金锄头文库上搜索。
物业保洁工作总结
商场国庆中两节营销活动策划方案模板
项目部重大安全事故应急预案改
安全:不搞恶作剧
门面房租赁协议标准范本(十一篇).doc
红枣养生:红枣泡水喝的功效与禁忌
2022年保险业工作总结范文4篇
福建内室承担检验检测项目资质情况表
2019年骨外科学历年真题精选
建筑生实习报告
钻进式井壁取芯1
u新亚专卖店管理手册
电能质量技术监督实施细则
2020年度困难职工帮扶中心工作统计表
最新21-小壁虎借尾巴-(2)教学设计
大四毕业优秀感言.doc
卫生局工作总结食品卫生安全宣传周活动工作总结
2022年中医药服务能力提升半年工作小结
高一化学必修二第三章测试题(DOC 8页)
伯牙绝弦公开课教学案和教学设计
2023-07-12 4页
2023-02-22 3页
2023-05-11 2页
2023-06-23 12页
2022-10-28 4页
2023-06-30 5页
2023-05-19 5页
2023-11-02 5页
2023-12-20 6页
2022-12-01 6页