第一范文网 - 专业文章范例文档资料分享平台

数据结构习题及答案

来源:用户分享 时间:2025/11/26 19:43:47 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

i++; } else /*若triple_a的当前项的行号大于triple_b的当前项的行号*/ /*则将triple_b的项存入triple_c中*/ { triple_c.data[k].i = triple_b.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; /*产生第0行的结果*/ triple_c.nu=triple_a.nu; triple_c.tu=k-1; }

}/*TripleTableAdd*/

5.有两个稀疏矩阵的三元组triple_a和triple_b,请写出利用三元组这种数据结构,实现将两个稀疏矩阵相加,最后的和存入三元组表triple_c之中的算法。

#define MAXSIZE 1000 /*假设非零元个数的最大值是1000*/

typedef struct { int i, j; elemtype v; }triple;

typedef struct { triple data[MAXSIZE+1]; /*data[0]用于存放稀疏矩阵行,列和非零元个数*/ int mu, nu, tu; /*稀疏矩阵行、列和非零元的个数*/

} spmatrix;

int TripleValue(spmatrix c, int i, int j) /*该函数用在TripleMul函数之中,计算三元组c相应的值*/ { int k=1; while (k<=c.tu && (c.data[k].i!=i || c.data[k].j!=j)) k++; if (k<=c.tu) return(c.data[k].v); /*找到了返回该位置的值*/ else return(0); /*未找到说明该元素为0*/ }/*TripleValue*/

void TripleMul(int m,int n,int k,spmatrix a,spmatrix b,spmatrix c) { int i,j,h,p=1,s; for (i=0;i

}/*TripleMul*/

6.有两个稀疏矩阵的三元组triple_a和triple_b,请写出利用三元组这种数据结构,实现将两个稀疏矩阵相乘,并将最后的乘积存人二元组表triple_c之中的算法。

搜索更多关于: 数据结构习题及答案 的文档
数据结构习题及答案.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c0xsh753yyv3qhtz4wk8r_12.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top