广义表的应用--稀疏矩阵的快速转置(三元组)
来源:互联网 发布:对外汉语教师网络兼职 编辑:程序博客网 时间:2024/05/22 05:03
#include<stdio.h>
#define MAXSIZE 10000
typedef struct{
int i,j;
int e;
}Triple;
typedef struct{
Triple data[MAXSIZE+1];
int mu,nu,tu;
}TSMatrix;
int row,col;
TSMatrix *CreateSMatrix(TSMatrix *M)
{
int m,n,p=1;
int c;
printf("please input 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("the old TSMatrix is:\n\n");
for(m=1;m<=M->tu;m++)
printf("%3d %3d %3d\n",M->data[m].i,M->data[m].j,M->data[m].e);
printf("\n");
return M;
}
TSMatrix *FastTransTSMatrix(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)
{
for(col=1;col<=M->nu;col++) num[col]=0;
for(t=1;t<=M->tu;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;p<=M->tu;++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("\nThe new TSMatrix is:\n");
for(m=1;m<=T->tu;m++)
printf("%3d%3d%3d\n",T->data[m].i,T->data[m].j,T->data[m].e);
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);
}
}
}
void main()
{
TSMatrix *M,*T;
M=(TSMatrix *)malloc(sizeof(TSMatrix));
T=(TSMatrix *)malloc(sizeof(TSMatrix));
printf("please input array's row and col:\n");
scanf("%d %d",&row,&col);
M=CreateSMatrix(M);
printf("The Creative array is:\n");
print(M,row,col);
T=FastTransTSMatrix(M,T);
printf("The trans's array is:\n");
print(T,row,col);
getch();
}
- 广义表的应用--稀疏矩阵的快速转置(三元组)
- 三元组稀疏矩阵的快速转置
- 数组与广义表_稀疏矩阵的压缩存储_三元组做存储结构_矩阵转置
- 三元组表压缩存储稀疏矩阵实现稀疏矩阵的快速转置(Java语言描述)
- 【数组与广义表项目3-2-稀疏矩阵的三元组的加法】
- 稀疏矩阵的三元组表示的应用(3.2)
- 三元组(稀疏矩阵的转置)
- 2015年大二上-数据结构-数组与广义表(3)-1.稀疏矩阵的三元组表示
- 2015年大二上-数据结构-数组与广义表(3)-2.稀疏矩阵的三元组表示
- 三元组表示矩阵,以及稀疏矩阵的转置
- 稀疏矩阵的三元组
- 稀疏矩阵的压缩存储与快速转置 三元组法 类与对象实现
- 数组与广义表_稀疏矩阵的压缩存储_三元组做存储结构_矩阵相乘
- 第九周 数据结构实践项目——数组和广义表【项目3.1-稀疏矩阵的三元组表示的实现及应用】
- 稀疏矩阵的三元组表示的实现及应用(2)——采用三元组存储稀疏矩阵,设计两个稀疏矩阵相加的运算算法
- 稀疏矩阵基于“三元组”的转置算法实现
- Sparse Matrix(稀疏矩阵三元组表示,三元组形式的矩阵转置)
- 稀疏矩阵的三元组表示的实现及应用(矩阵相加)
- GetSafeHwnd()
- 【子实推荐/史海钩沉】国军抗战全纪实——100集系列纪录片
- 开心一下
- 转载 :ext spket,ext提示工具安装
- DMZ
- 广义表的应用--稀疏矩阵的快速转置(三元组)
- 控制飞机的移动
- 每天任务的高效管理办法
- 关于request.setAttribute("message", message);不能传int参数的原因
- PHP单例模式在MVC框架设计中的应用
- ThinkPHP叫号系统
- 已知二叉树的先序、中序遍历序列,求其后序遍历结果。(hduoj1710)
- Linux 下zip包的压缩与解压
- AfxGetApp()