网站大量收购独家精品文档,联系QQ:2885784924

数据结构与管理串和数组实验报告.doc

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构与管理串和数组实验报告

实验一 实验目的 1、掌握串的有关运算; 2、掌握矩阵的顺序存储形式; 实验题目 1、利用串的顺序定长存储结构实现两个子串的连接。 要求:两个子串从键盘输入获得;从屏幕显示连接后的新串元素列表。 2 、利用串的堆分配存储结构实现两个子串的连接。 要求:两个子串从键盘输入获得;从屏幕显示连接后的新串元素列表。 3 、将已知的稀疏矩阵进行转置运算。 要求:从键盘输入矩阵的元素,用三元组表进行存储,显示稀疏矩阵的元素;调用稀疏矩阵(三元组存储结构)转置算法,显示转置后的稀疏矩阵的元素。 源程序#includestdio.h #includestring.h #define MAXSTRLEN 255 typedef char SString[MAXSTRLEN+1]; SString L,S; void main() { int i,m,n; printf(输入第一个串:); gets(L); printf(输入第二个串:); gets(S); m=strlen(L); n=strlen(S); for(i=0;i=n;i++) L[i+m]=S[i] ; printf(%s,L); printf(\n); } 2、#includestdio.h #includemalloc.h #includestring.h #define MAXSTRLEN 255 typedef char SString[MAXSTRLEN]; typedef struct{ char *ch; int length;}HString; SString L,S; HString R,T; void main() { int i; printf(输入第一个串:); gets(L); printf(输入第二个串:); gets(S); R.length=strlen(L); T.length=strlen(S); R.ch=(char *)malloc((R.length)*sizeof(char)); strcpy(R.ch,L); T.ch=(char *)malloc((T.length)*sizeof(char)); strcpy(T.ch,S); //重新分配空间 R.ch=(char*)realloc(R.ch,(R.length+R.length+1)*sizeof(char)); //连接 for(i=0;i=T.length;i++) R.ch[R.length+i]=T.ch[i]; printf(连接后为:\n%s,R.ch); printf(\n); } 3、#includestdio.h #define MAXSIZE 12500 typedef int ElemType; typedef struct{ int a,b; //a是行序号,b是列序号 ElemType e; }Triple; typedef struct{ Triple date[MAXSIZE+1]; int mu,nu,tu; }TSMatrix; void main() { int i,j,col; int p=1,q=1; TSMatrix M,T; printf(输入M矩阵的行和列:); scanf(%d,%d,M.mu,M.nu); printf(输入三元组,(以0结束 每输入一个三元组后按enter)\n); scanf(%d,%d,%d,M.date[p].a,M.date[p].b,M.date[p].e); while(M.date[p].a!=0) { p++; scanf(%d,%d,%d,M.date[p].a,M.date[p].b,M.date[p].e); } M.tu=p-1; printf(非零元素的个数为:%d\n,M.tu); printf(输出M矩阵:\n); p=1; for(i=1;i=M.mu;i++) {for(j=1;j=M.nu;j++) if(i==M.date[p].aj==M.date[p].b) printf(%6d,M.date[p++].e); else printf(%6c,0); printf(\n); } //实现转置 T.mu=M.nu; T.nu=M.mu; T.tu=M.tu; for(col=1;col=M.nu;++col) for(p=1;p=M.tu;p++) if(M.date[p].b==col) { T.date[q].a=M.date[p].b; T.date[q].b=M.date[p].a

文档评论(0)

haihang2017 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档