资源描述:
《数据结构实验报告3》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、数学与软件科学学院实验报告学期:12至_13第_1学期时间:2012年5月18日课程名称:数据结构专业:信息与计算科学实验编号:5实验项目:稀疏矩阵的三元组实现实验实验成绩:一、实验目的及要求掌握稀疏矩阵的三元组表示方法、算法实现。二、实验内容(1)基于三元组的稀疏矩阵表示与输入、输出方法(必做);(2)基于三元组的稀疏矩阵加法(选做);(3)基于三元组表示的稀疏矩阵转置(选做);(4)基于三元组表示的稀疏矩阵的乘法(选做)。三、实验准备:1)计算机设备;2)程序调试环境的准备,如TC环境;3)实验内容的算法分析与代码设计与分析准备。四、实验步骤:1.录入程
2、序代码并进行调试和算法分析;2.编写实验报告。1,对实验问题的描述:采用矩阵的压缩存储可以减少存储矩阵的空间:即为多个值相同的元只分配一个存储空间;对零元不分配存储空间,只需存储稀疏矩阵的非零元。可以采用一个三元组(i,j,a)确定矩阵的非零元,由此,稀疏矩阵可由表示非零元的三元组及其行列数唯一确定。按照稀疏矩阵的三元组实现矩阵的输入输出,相加,相乘的基本操作。2,算法的数据结构#defineMAXSIZE1000typedefstruct{nti,j;ElemTypev;}Triple;typedefstruct{Tripledata[MAXSIZE+1]
3、;intmu,nu,tu;}Spmatrix;3,算法基本操作的说明及分析1,稀疏矩阵的创建intCreatTriple(Spmatrix*a){inti;printf("inputthemaxrowandcolscriptandthenumberofunzeroelement(mu,nu,tu)::");scanf("%d,%d,%d",&a->mu,&a->nu,&a->tu);printf("inputthecolandrowscriptforeachItem(i,j,v)::");for(i=1;i<=a->tu;i++){scanf("%d,%
4、d,%d",&a->data[i].i,&a->data[i].j,&a->data[i].v);}returnOK;}2,两个稀疏矩阵相加intTripleAdd(Spmatrixtriple_a,Spmatrixtriple_b,Spmatrix*triple_c){inti=1,j=1,k=1;if((triple_a.mu!=triple_b.mu)
5、
6、(triple_a.nu!=triple_b.nu)){printf("TheScriptisdifferent!");exit(0);}else{while(i<=triple_a.tu&&j<=t
7、riple_b.tu){if(triple_a.data[i].jdata[k].i=triple_a.data[i].i;triple_c->data[k].j=triple_a.data[i].j;triple_c->data[k].v=triple_a.data[i].v;k++;i++;}elseif(triple_a.data[i].j>triple_b.data[j].j){triple_c->data[k].i=triple_b.data[j].i;triple_c->data[k]
8、.j=triple_a.data[j].j;triple_c->data[k].v=triple_a.data[j].v;k++;j++;}else{triple_c->data[k].i=triple_b.data[j].i;triple_c->data[k].j=triple_a.data[j].j;triple_c->data[k].v=triple_a.data[i].v+triple_b.data[j].v;k++;i++;j++;}}elseif(triple_a.data[i].id
9、ata[k].i=triple_a.data[i].i;triple_c->data[k].j=triple_a.data[i].j;triple_c->data[k].v=triple_a.data[i].v;k++;i++;}else{triple_c->data[k].i=triple_a.data[j].i;triple_c->data[k].j=triple_b.data[j].j;triple_c->data[k].v=triple_b.data[j].v;k++;j++;}}triple_c->mu=triple_a.mu;triple_c->
10、nu=triple_a.nu;triple_c->t