当前位置:文档之家› 稀疏矩阵转换三元组并转置(c语言)

稀疏矩阵转换三元组并转置(c语言)

#include
#include
#define MAXSIZE 100
typedef struct {
int i,j;
int e;
}Triple;
typedef struct{
Triple data[MAXSIZE+1];
int mu,nu,tu;
} Tsmatrix;

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

/*用数组创建三元组*/
Tsmatrix * creatarray(Tsmatrix *M)
{ int m,n,p=1;
int c;
printf("please input the array A:\n");
for(m=1;m<=a;m++)
for(n=1;n<=b;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=a; M->nu=b;
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()
{ Tsmatrix *M,*T;
M=(Tsmatrix *)malloc(sizeof(Tsmatrix));
T=(Tsmatrix *)malloc(sizeof(Tsmatrix));
printf("请输入行数和列数:\n");
scanf("%d%d",&a,&b); /*输入行列数*/
M=creatarray(M);
printf("创建的矩阵为:\n");
print(M,a,b);
T=fasttrans(M,T);
printf("转置后的矩阵为:\n");
print(T,b,a);
// getch();
}

相关主题
文本预览
相关文档 最新文档