数据结构实验6稀疏矩阵.doc

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

实验目的 掌握稀疏矩阵三元组表的存储方法; 掌握稀疏矩阵三元组表的创建、显示、转置和查找算法。 实验内容 编写稀疏矩阵三元组表的存储程序; 编写稀疏矩阵三元组表的创建、显示、转置和查找程序。 实验要求 用C(C++)语言完成算法设计和程序设计。 上机调试通过实验程序。 输入数据,检验程序运行结果。 给出具体的算法分析,包括时间复杂度和空间复杂度等。 撰写实验报告(把输入实验数据及运行结果用抓图的形式粘贴到实验报告上)。 实验步骤与源程序 ⑴ 实验步骤 先从具体的问题中抽象出适当的数学模型,然后设计出相应的算法,其中,需要设计一个主函数来实现菜单的输出,设计另外五个函数来求分别实现新建,转置,查找,显示,最后,串接函数,并调试程序,在调试的时候,我先进行新建操作,输入数据之后,然后开始转置操作,再进行查找其中的非零元素,多次调试后,发现没有问题,得出实验结果,并截图。 ⑵ 源代码 #includestdio.h #includeiomanip.h #includestdlib.h #includestring.h #define SMAX 100 // 三元组非零元素的最大个数 typedef struct SPNode // 定义三元组 { int i,j,v; // 三元组非零元素的行、列和值 }; typedef struct sparmatrix // 定义稀疏矩阵 { int rows,cols,terms; // 稀疏矩阵行、列和非零元素的个数 SPNode data[SMAX]; // 三元组表 }; sparmatrix CreateSparmatrix() // 创建稀疏矩阵 { sparmatrix A; printf(\n\t\t请输入稀疏矩阵的行数,列数和非零元个数(用逗号隔开): ); scanf(%d,%d,%d,A.rows,A.cols,A.terms); for(int n=0;n=A.terms-1;n++) { printf(\n\t\t输入非零元值(格式: 行号,列号,值): ); scanf(%d,%d,%d,A.data[n].i,A.data[n].j,A.data[n].v); } return A; } sparmatrix Trans(sparmatrix A) // 转置稀疏矩阵 { sparmatrix B; B.rows=A.cols; B.cols=A.rows; B.terms=A.terms; for(int n=0;n=A.terms-1;n++) { B.data[n].i=A.data[n].j; B.data[n].j=A.data[n].i; B.data[n].v=A.data[n].v; } return B; } void ShowSparmatrix(sparmatrix A) // 显示稀疏矩阵 { int k; printf(\n\t\t); for(int x=0;x=A.rows-1;x++) { for(int y=0;y=A.cols-1;y++) { k=0; for(int n=0;n=A.terms-1;n++) { if((A.data[n].i==x)(A.data[n].j==y)) { printf(%8d,A.data[n].v);k=1;} } if(k==0) printf(%8d,k); } printf(\n\t\t); } } void SearchSparmatrix(sparmatrix A,int s) // 查找稀疏矩阵中非零元素 { int n,t; t=A.terms; for(n=0;nt;n++) { if(A.data[n].v==s) { printf(\n\t\t 行 列 值\n); printf(\n\t\t元素位置:%2d %2d %2d\n, A.data[n].i,A.data[n].j,A.data[n].v); n=-1; break; } } if(n

文档评论(0)

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

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

1亿VIP精品文档

相关文档