数据结构实验——稀疏矩阵的存储和快速转置

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

#include
#include
#define MAXSIZE 100

typedef struct {
int i,j;//位置
int e;//数据元素
}Triple;//三元组

typedef struct{
Triple data[MAXSIZE+1];
int mu,nu,tu;//mu行数 nu列数 tu总长度
} Tsmatrix;//矩阵

int a,b; /*定义全局变量数组的行数a和列数b*/

/*用数组创建三元组*/
Tsmatrix * creatarray(Tsmatrix *M,int row,int col)
{ int m,n,p=1;
int c;
printf("please input the array A:\n");
for(m=1;m<=row;m++)
for(n=1;n<=col;n++)
{ scanf("%d",&c);
if(c!=0)
{ M->data[p].e=c;
M->data[p].i=m;
M->data[p].j=n;
p++;
}
}
M->tu=p; M->mu=row; M->nu=col;
printf("原矩阵三元组表示为 :\n\n");
for(m=1;mtu;m++)
printf("%3d%3d%3d\t\n",M->data[m].i,M->data[m].j,M->data[m].e);
printf("\n");
return M;
}
/*三元组快速转置*/
Tsmatrix * fasttrans(Tsmatrix *M,Tsmatrix *T)
{
int p,col,q,t,m;
int num[100];
int cpot[100];
T->mu=M->nu; T->nu=M->mu; T->tu=M->tu;
if(T->tu!=0)
{
for(col=1;col<=M->nu;++col)
num[col]=0;
for(t=1;ttu;++t)
num[M->data[t].j]++;
cpot[1]=1;
for(col=2;col<=M->nu;++col)
cpot[col]=cpot[col-1]+num[col-1];
for(p=1;ptu;++p)
{
col=M->data[p].j;
q=cpot[col];
T->data[q].i=M->data[p].j;
T->data[q].j=M->data[p].i;
T->data[q].e=M->data[p].e;
++cpot[col];
}
}
printf("\n转置之后的三元组表示 :\n");
for(m=1;mtu;m++)
printf("%3d%3d%3d\t\n",T->data[m].i,T->data[m].j,T->data[m].e);
printf("\n");
return T;
}
/*输出三元组函数*/


void print(Tsmatrix *T,int x,int y)
{
int m,n,p=1;
int d;
for(m=1;m<=x;m++)
{ printf("\n");
for(n=1;n<=y;n++)
{ if(T->data[p].i==m&&T->data[p].j==n)
{ d=T->data[p].e;
p++;
}
else d=0;
printf("%6d",d);
}
}
printf("\n");
}
void main()
{
int row,col;
Tsmatrix *M,*T;
M=(Tsmatrix *)malloc(sizeof(Tsmatrix));
T=(Tsmatrix *)malloc(sizeof(Tsmatrix));
printf("请输入行数和列数:\n");
scanf("%d%d",&row,&col); /*输入行列数*/
M=creatarray(M,row,col);
printf("创建的矩阵为:\n");
print(M,row,col);
T=fasttrans(M,T);
printf("转置后的矩阵为:\n");
print(T,col,row);
// getch();
}

相关文档
最新文档