用三元组表存储表示,求稀疏矩阵M转置函数T

时间:2022-07-03 11:44:11 阅读: 最新文章 文档下载
说明:文章内容仅供预览,部分内容可能不全。下载后的文档,内容与下面显示的完全一致。下载之前请确认下面内容是否您想要的,是否完整无缺。
用三元组表存储表示,求稀疏矩阵M转置函数T

实验目的

采用三元组表存储表示,求稀疏矩阵M转置函数T 实验内容

编程序并上机调试运行。

采用三元组表存储表示,求稀疏矩阵M转置函数T 编写程序

//采用三元组表存储表示,求稀疏矩阵M转置函数T #include #define MAXSIZE 100 typedef struct { int i,j; int e; }Triple; typedef struct {

Triple data[MAXSIZE+1]; int mu,nu,tu; }TSMatrix; //创建稀疏矩阵M

CreateSMatrix(TSMatrix *M) {

int i,m,n,e,k;


printf("输入矩阵M的行数、列数、非零元的个数(中间用逗号隔开):"); scanf("%d,%d,%d",&(*M).mu,&(*M).nu,&(*M).tu); (*M).data[0].i=0; printf("\n");

for(i=1;i<=(*M).tu;i++) { do {

printf("输入第%d个非零元素所在的行(1~%d)(1~%d)值以及该数值: ",i,(*M).mu,(*M).nu); scanf("%d,%d,%d",&m,&n,&e); k=0;

if(m<1||m>(*M).mu||n<1||n>(*M).nu) k=1;

if(m<(*M).data[i-1].i||m==(*M).data[i-1].i&&n<(*M).data[i-1].j) k=1; }while(k); (*M).data[i].i=m; (*M).data[i].j=n; (*M).data[i].e=e; }

printf("\n"); return 1; }


//输出稀疏矩阵M

void PrintSMatrix(TSMatrix M) { int i;

printf("**************************************\n"); for(i=1;i<=M.tu;i++)

printf("%2d%4d%8d\n",M.data[i].i,M.data[i].j,M.data[i].e); printf("**************************************\n"); printf("\n"); }

//求稀疏矩阵M的转置矩阵T

void TransposeSMatrix(TSMatrix M,TSMatrix *T) {

int p,q,col; (*T).mu=M.nu; (*T).nu=M.mu; (*T).tu=M.tu; if((*T).tu) { q=1;

for(col=1;col<=M.nu;++col) for(p=1;p<=M.tu;++p) if(M.data[p].j==col)

{ (*T).data[q].i=M.data[p].j; (*T).data[q].j=M.data[p].i;


本文来源:https://www.wddqw.com/doc/ced485cabb0d6c85ec3a87c24028915f814d8490.html