欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    【数据结构算法】实验3稀疏矩阵基本操作顺序结构(附源代码).pdf

    • 资源ID:85907445       资源大小:364.63KB        全文页数:10页
    • 资源格式: PDF        下载积分:14.9金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要14.9金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    【数据结构算法】实验3稀疏矩阵基本操作顺序结构(附源代码).pdf

    浙江大学城市学院实验报告 课程名称 数据结构与算法 实验项目名称 实验三 稀疏矩阵的基本操作-用顺序存储结构 实验成绩 指导老师(签名)日期 一.实验目的和要求 1了解稀疏矩阵的三元组线性表存储方法。2掌握稀疏矩阵采用顺序存储结构时基本操作的实现。二.实验内容 1 编写稀疏矩阵采用顺序存储结构时基本操作的实现函数。基本操作包括:初始化稀疏矩阵;输入稀疏矩阵;输出稀疏矩阵;稀疏矩阵的相加运算。要求把稀疏矩阵的存储结构定义及基本操作实现函数存放在头文件SeqMatrix.h 中,主函数 main()存放在主文件 test7_1.cpp 中,在主函数中通过调用 SeqMatrix.h 中的函数进行测试。2 选做:编写稀疏矩阵的相乘运算实现函数,要求把该函数添加到头文件SeqMatrix.h 中,并在主文件 test7_1.cpp 中添加相应语句进行测试。3 填写实验报告,实验报告文件取名为 report3.doc。4 上传实验报告文件 report3.doc 与源程序文件 SeqMatrix.h 及test7_1.cpp 到 Ftp 服务器上你自己的文件夹下。三.函数的功能说明及算法思路 包括每个函数的功能说明,及一些重要函数的算法实现思路 函数:void InitMatrix(SMatrix&M)功能:初始化稀疏矩阵 思路:将稀疏矩阵的行、列、元素个数均置为0 函数:void InputMatrix(SMatrix&M,int m,int n)功能:输入稀疏矩阵 思路:以行、列、值的方式输入稀疏矩阵的每个元素 函数:void OutputMatrix(SMatrix M)功能:输出稀疏矩阵 思路:以行、列、值的方式输出稀疏矩阵的每个元素 函数:SMatrix Add(SMatrix M1,SMatrix M2)功能:稀疏矩阵的相加运算 思路:遍历 M1 与 M2,若两者的当前元素行列号相等则将值相加,形成新的元素加入结果矩阵 M(若为 0 则忽略),若不相等则按行列号顺序将小的那个加入结果矩阵 M 函数:SMatrix Multiply(SMatrix M1,SMatrix M2)功能:选作:稀疏矩阵的相乘运算 思路:嵌套遍历 M1 与 M2,当 M1 的当前元素列号与 M2 的当前元素行号相等时相乘两个数,并将结果暂存入单链表。遍历保存结果的单链表,对单链表内元素按行号(实际行号已有序)、列号从小到大排序,同时,判断是否有属于结果矩阵同一个元素的结点,将他们的值加至同一个结点。每结束一个结点的遍历,该值确定,加入结果矩阵 M 中 四.实验结果与分析 包括运行结果截图等 测试数据:M1、M2 如图所示-10 2 7 M1 M2 结果分析:相加结果 M 如图所示,正确-10 3 -1 22 3 -2 -1 15 测试数据:M1、M2 如图所示 8 8 6 M1 M2 结果分析:相乘结果 M 如图所示,正确 84 70 测试数据:M1、M2 如图所示 5 2 1 3 6 5 7 15 -1 -2 21 M1 M2 结果分析:相加结果 M 如图所示,正确 9 5 15 -1 21 4 11 测试数据:M1、M2 如图所示 M1 M2 结果分析:相乘结果 M 如图所示,正确 2 5 1 4 11 0 2 3 1 1 2 1 1 2 0 1 3 5 0 4 6 五.心得体会 记录实验感受、上机过程中遇到的困难及解决办法、遗留的问题、意见和建议等。【附录-源程序】Test7_1.cpp#include#include#include#includeSeqMatrix.h void main()SMatrix M1,M2,M;int m,n;InitMatrix(M1);coutmn;cout-M1-endl;InputMatrix(M1,m,n);InitMatrix(M2);cout-M2-endl;InputMatrix(M2,m,n);cout-M1+M2-endl;OutputMatrix(Add(M1,M2);coutendl*以下为选作部分*endlendl;InitMatrix(M1);cout-M1-endl;coutmn;InputMatrix(M1,m,n);InitMatrix(M2);cout-M2-endl;coutmn;InputMatrix(M2,m,n);M=Multiply(M1,M2);cout-M1*M2-endl;cout行数:M.m 列数:M.nendl;OutputMatrix(M);SeqMatrix.h#define MaxTerms 100 typedef int ElemType;typedef struct int row,col;ElemType val;Triple;typedef struct int m,n,t;Triple smMaxTerms+1;SMatrix;struct LNode Triple t;LNode*next;/初始化稀疏矩阵 void InitMatrix(SMatrix&M)M.m=0;M.n=0;M.t=0;/输入稀疏矩阵 void InputMatrix(SMatrix&M,int m,int n)int k=0;int row,col,val;M.m=m;M.n=n;cout请输入 row,col,val,以 0 0 0 结尾:rowcolval;while(row!=0)k+;M.smk.row=row;M.smk.col=col;M.smk.val=val;cinrowcolval;M.t=k;/输出稀疏矩阵 void OutputMatrix(SMatrix M)int k=1;cout 1)cout(M.smk.row,M.smk.col,M.smk.val),;k+;cout(M.smk.row,M.smk.col,M.smk.val)endl;/稀疏矩阵的相加运算 SMatrix Add(SMatrix M1,SMatrix M2)int k1=1,k2=1;SMatrix M;Triple t;InitMatrix(M);if(M1.m!=M2.m)|(M1.n!=M2.n)cerrtow Matrix measurenents are different!endl;exit(1);M.m=M1.m;M.n=M1.n;while(k1=M1.t&k2=M2.t)if(M1.smk1.row=M2.smk2.row&M1.smk1.col=M2.smk2.col)t.val=M1.smk1.val+M2.smk2.val;if(t.val)t.row=M1.smk1.row;t.col=M1.smk1.col;M.sm+M.t=t;k1+;k2+;else if(M1.smk1.row=M2.smk2.row)M.sm+M.t=M1.smk1.col M2.smk2.col?M1.smk1+:M2.smk2+;else M.sm+M.t=M1.smk1.row M2.smk2.row?M1.smk1+:M2.smk2+;while(k1=M1.t)M.sm+M.t=M1.smk1;k1+;while(k2=M2.t)M.sm+M.t=M2.smk2;k2+;return M;/选作:稀疏矩阵的相乘运算 SMatrix Multiply(SMatrix M1,SMatrix M2)int k1=1,k2=1;LNode*L,*p,*T;SMatrix M;InitMatrix(M);if(M1.n!=M2.m)cerrtow Matrix measurenents are different!next=NULL;p=L;/嵌套遍历 M1 与 M2,当 M1 的当前元素列号与 M2 的当前元素行号相等时 /相乘两个数,并将结果暂存入单链表 while(k1=M1.t)while(M2.smk2.row=M1.smk1.col&k2 t.row=M1.smk1.row;T-t.col=M2.smk2.col;T-t.val=M1.smk1.val*M2.smk2+.val;T-next=NULL;p-next=T;p=T;else k2+;k2=1;k1+;L=L-next;p=L;/遍历保存结果的单链表 /对单链表内元素按行号(实际行号已有序)、列号从小到大排序 /同时,判断是否有属于结果矩阵同一个元素的结点,将他们的值加至同一个结点 /每结束一个结点的遍历,该值确定,加入结果矩阵 M 中 while(p!=NULL)if(p-t.val=0)p=p-next;continue;T=p-next;while(T!=NULL&T-t.row=p-t.row)while(T!=NULL&T-t.val=0)T=T-next;if(T-t.col t.col)Triple temp;temp=p-t;p-t=T-t;T-t=temp;T=p-next;else if(T-t.col=p-t.col)p-t.val+=T-t.val;T-t.val=0;T=T-next;else T=T-next;M.sm+M.t=p-t;p=p-next;return M;

    注意事项

    本文(【数据结构算法】实验3稀疏矩阵基本操作顺序结构(附源代码).pdf)为本站会员(g****s)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开