- 4
- 0
- 约1.96千字
- 约 3页
- 2021-10-12 发布于湖南
- 举报
用三元组表存储表示,求稀疏矩阵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(\ (*M).data[0].i=0; printf(\ for(i=1;i=(*M).tu;i++) {
do { printf(\输入第%d个非零元素所在的行(1~%d)列(1~%d)值以及该数值:\
scanf(\ k=0; if(m1||m(*M).mu||n1||n(*M).nu) k=1; if(m
//输出稀疏矩阵M
void PrintSMatrix(TSMatrix M) { int i; printf(\ for(i=1;i=M.tu;i++) printf(\printf(\ printf(\}
//求稀疏矩阵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; (*T).data[q].e=M.data[p].e; ++q; } } return 1; }
//打印矩阵函数,以通常形式输出矩阵 void print(TSMatrix A) { int k=1,a,b; int M[MAXSIZE][MAXSIZE]; printf(\非零元素所对应的位置:\\n\
printf(\ for(a=0;a
printf(\ printf(\}
//主函数 int main() {
TSMatrix M,T; printf(\创建矩阵M:\ CreateSMatrix(M); printf(\矩阵M的三元组表为:\\n\ PrintSMatrix(M); print(M); TransposeSMatrix(M,T); printf(\稀疏矩阵M的转换矩阵T的三元组表为:\\n\ PrintSMatrix(T); print(T);
printf(\ getchar(); return 0; }
运行程序:
程序解析:
1.首先是将程序的开头写好,定义非零元个数最多为100.
定义非零元的行下标,列下标,和非零元素为int型。由mu,nu,tu分别代表矩阵的行数,列数和非零元个数。
2.创建稀疏矩阵M。
创建一个稀疏矩阵,用scanf进行用户输入行数,列数及非零元个数。当i小于等于非零元个数时,进行以下的for循环,执行内循环的循环语句。当k不为0时,重复执行输入非零元素的行列值以及其值,若超出行数或列数或非零元个数,则跳出循环。加入外循环,执行外循环的三个语句,直到,i等于非零个数,跳出外循环。
感谢您的阅读,祝您生活愉快。
原创力文档

文档评论(0)