C22-矩阵的乘法-乘方运算的C程序

C22-矩阵的乘法-乘方运算的C程序

ID:38104922

大小:17.52 KB

页数:4页

时间:2019-06-06

C22-矩阵的乘法-乘方运算的C程序_第1页
C22-矩阵的乘法-乘方运算的C程序_第2页
C22-矩阵的乘法-乘方运算的C程序_第3页
C22-矩阵的乘法-乘方运算的C程序_第4页
资源描述:

《C22-矩阵的乘法-乘方运算的C程序》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、//矩阵的乘法、乘方运算的C语言程序//求两个矩阵的乘积及方阵的乘方#include//getch#include//printf,scanf#include//time#include//srand,rand//============抽象数据类型矩阵的表示============//typedefstruct{//矩阵的定义double*p;//矩阵数据存放的首地址introw;//行数intcol;//列数}Matrix;//============抽象

2、数据类型矩阵的实现============//voidInitMat(Matrix&m)//初始化为空{m.p=NULL;m.row=0;m.col=0;}voidErrExit(char*s){//遇错退出并提示printf("%s!",s);getch();exit(0);}voidInitMat(Matrix&m,intr,intc){//初始化指针及行列数if(r<=0

3、

4、c<=0)ErrExit("矩阵型行列数错");m.p=newdouble[r*c];m.row=r;m.col=c;}voidRandMat(

5、Matrix&m){//给矩阵赋随机值for(inti=0;i

6、.col;j++)if(i==j)*(m.p+i*m.col+j)=1;else*(m.p+i*m.col+j)=0;}voidPrintMat(Matrixm,char*str){//输出矩阵的所有值printf("矩阵%s为:",str);for(inti=0;i

7、p;m.p=NULL;}voidMulMat(Matrix&m,Matrixa,Matrixb){//求两矩阵的积if(a.col!=b.row)ErrExit("相乘失配");//矩阵失配不能相乘InitMat(m,a.row,b.col);//申请空间ClearMat(m);//清空矩阵为全0for(inti=0;i

8、+j);}voidCopyMat(Matrixd,Matrixs){//拷贝矩阵s至dif(d.row!=s.row

9、

10、d.col!=s.col)ErrExit("拷贝扮配");for(inti=0;i

11、(x,a.row,a.col);UnitMat(x);//构造单位阵xif(n==0){InitMat(m,a.row,a.col);CopyMat(m,x);}for(unsignedi=1;i<=n;i++){if(m.p)Destroy(m);//MulMat后必须销毁mMulMat(m,x,a);CopyMat(x,m);}Destroy(x);}//下面的程序似乎更简单,但是没有清理内存voidPowMat2(Matrix&m,Matrixa,unsignedn){//求矩阵的乘方InitMat(m,a.row,a.co

12、l);UnitMat(m);for(unsignedi=1;i<=n;i++)MulMat(m,m,a);}//=====================程序测试=================//voidmain(){Matrixm,a,b,c

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。