数组和广义表实验.docVIP

数组和广义表实验.doc

此“教育”领域文档为创作者个人分享资料,不作为权威性指导和指引,仅供参考
  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数组和广义表 班级:软件102 姓名: 学号: 完成日期:2011.11.25 题目:数组转置 题目描述:存在稀疏矩阵A,编写程序将A转置为B。 基本要求:用三元组表示稀疏矩阵,应用算法5.2完成转置 需求分析 功能:求一个用三元组表示的矩阵 的转置矩阵 输入:矩阵的行数、列数、非零元的个数、非零元对应的行下标和列下标 输出:转置后的矩阵 二、概要设计 有题目要求知,需要建立一个三元组的结构体,和转置的函数;由此可以得到需要以下几个模块 模块: 三元组表示的结构体 快速转置的函数 大概算法: 模块2: 先求出每一列所含非零元的个数,然后找出每一列第一个存储的位置依次进行转置 三、详细设计 从键盘输入一个稀疏矩阵 printf(请输入要转置行列式的行和列的值:); scanf(%d%d,x,y); printf(请输入此稀疏矩阵的元素:\n); for(i=1;i=x;i++) for(j=1;j=y;j++) scanf(%d,A[i][j]); 把输入的一个一维矩阵转换为一个三元组 for(i=1;i=x;i++) for(j=1;j=y;j++) if(A[i][j]!=0) { B.data[k].row=i; B.data[k].col=j; B.data[k].e=A[i][j]; k++; } B.m=x; //三元表的行数 B.n=y; //三元表的列数 B.len=k-1; 3.三元组的转置 void TransposeTSMatrix(TSMatrix *A,TSMatrix *B) { int i,j,k; B-m=A-n; B-n=A-m; B-len=A-len; if(B-len0) { j=1; for(k=1;k=A-n;k++) for(i=1;i=A-len;i++) if(A-data[i].col==k) { B-data[j].row=A-data[i].col; B-data[j].col=A-data[i].row; B-data[j].e=A-data[i].e; j++; } } } 4.三元组表的输出 for(i=1;i=C.m;i++){ for(j=1;j=C.n;j++){ if((C.data[p].row==i)(C.data[p].col==j)){ printf(%d ,C.data[p].e); p++; } else printf(0 ); } printf(\n); } 四、调试分析: 调试结果,检查出程序的错误地方。并且对程序不足的地方进行一步步修改,因为哪怕程序是正确的,也可能存在太多问题。一定要通过调试解决。 五、测试结果 1.第一组测试数据: 结果正确。 2.第二组测试数据: 结果正确 六、程序清单 #includestdio.h #define MAXSIZE 1000 typedef struct { int row,col; int e; }Triple; typedef struct { int mu,nu,len; Triple data[MAXSIZE+1]; }TSMatrix; void TSTSMatrix(TSMatrix *A,TSMatrix *B) { int i,j,k; B-mu=A-nu; B-nu=A-mu; B-len=A-len; if(B-len0) { j=1; for(k=1;k=A-nu;k++) for(i=1;i=A-len;i++) if(A-data[i].col==k) { B-data[j].row=A-data[i].col; B-data[j].col=A-data[i].row; B-data[j].e=A-data[i].e; j++; } } } int main() { int x,y,i,j; int k=1,p=1; TSMatrix B,C; int A[100][100]; printf(请输入要转置行列式的行和列的值:); scanf(%d%d,x,y); printf(请输入

文档评论(0)

phl805 + 关注
实名认证
文档贡献者

建筑从业资格证持证人

该用户很懒,什么也没介绍

领域认证该用户于2023年05月12日上传了建筑从业资格证

1亿VIP精品文档

相关文档