三元组表示稀疏矩阵的转置一般算法和快速算法Word文档下载推荐.docx
- 文档编号:15374942
- 上传时间:2022-10-29
- 格式:DOCX
- 页数:21
- 大小:66.32KB
三元组表示稀疏矩阵的转置一般算法和快速算法Word文档下载推荐.docx
《三元组表示稀疏矩阵的转置一般算法和快速算法Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《三元组表示稀疏矩阵的转置一般算法和快速算法Word文档下载推荐.docx(21页珍藏版)》请在冰豆网上搜索。
{
Tripledata[MAXSIZE+1];
//非零元三元组表
intrpos[MAXRC+1];
//各行第一个非零元的位置表
intmu,nu,tu;
//矩阵的行数、列数和非零元个数
}RLSMatrix;
例如有矩阵A,它与其三元组表的对应关系如图
2.2系统功能设计
本系统通过菜单提示用户首先选择稀疏矩阵转置方法,然后提示用户采用三元组表示法输入数据创建一个稀疏矩阵,再进行矩阵的转置操作,并以通常的阵列形式输出结果。
主要实现以下功能。
(1)创建稀疏矩阵。
采用带行逻辑连接信息的三元组表表示法,提示用户输入矩阵的行数、列数、非零元个数以及各非零元所在的行、列、值。
(2)矩阵转置。
<
1>
采用一般算法进行矩阵的转置操作,再以阵列形式输出转置矩阵B。
2>
采用快速转置的方法完成此操作,并以阵列形式输出转置矩阵B。
三、模块设计
3.1模块设计
程序包括两个模块:
主程序模块、矩阵运算模块。
3.2系统子程序及其功能设计
系统共设置了8个子程序,各子程序的函数名及功能说明如下。
(1)CreateSMatrix(RLSMatrix&
M)//创建稀疏矩阵
(2)voidDestroySMatrix(RLSMatrix&
M)//销毁稀疏矩阵
(3)voidPrinRLSMatrix(RLSMatrixM)//遍历稀疏矩阵
(4)voidprint(RLSMatrixA)//打印矩阵函数,输出以阵列形式表示的矩阵
(5)TransposeSMatrix(RLSMatrixM,RLSMatrix&
T)//求稀疏矩阵的转置的一般算法
(6)FastTransposeSMatrix(RLSMatrixM,RLSMatrix&
T)//快速转置算法
(7)voidshowtip()//工作区函数,显示程序菜单
(8)voidmain()//主函数
3.3程序主要调用关系图
四、详细设计
4.1数据类型定义
采用矩阵“带行逻辑连接信息”的三元组顺序表存储结构。
4.2系统主要子程序详细设计
(1)主函数:
voidmain()
{
intresult;
intj;
RLSMatrixA,B;
COORDCo={0,0};
DWORDWrite;
SetConsoleTitle("
稀疏矩阵的转置"
);
HANDLEhOut=GetStdHandle(STD_OUTPUT_HANDLE);
SetConsoleTextAttribute(hOut,FOREGROUND_RED|FOREGROUND_BLUE|FOREGROUND_INTENSITY);
FillConsoleOutputAttribute(hOut,FOREGROUND_RED|FOREGROUND_BLUE|FOREGROUND_INTENSITY,100000000,Co,&
Write);
///windows的API函数,用来设置控制台标题及颜色。
do
showtip();
//调用菜单函数
inti;
scanf("
%d"
&
i);
switch(i)
{
case1:
printf("
创建矩阵A:
"
if((result=CreateSMatrix(A))==0)
exit(ERROR);
矩阵A的三元组表为:
\n"
PrinRLSMatrix(A);
求A的转置矩阵B(一般算法):
TransposeSMatrix(A,B);
矩阵B的三元组表为:
PrinRLSMatrix(B);
以通常的阵列形式输出转置前的矩阵A:
print(A);
\n\n"
以通常的阵列形式输出转置后的矩阵B:
print(B);
DestroySMatrix(B);
printf("
break;
case2:
printf("
PrinRLSMatrix(A);
求A的转置矩阵B(快速转置):
FastTransposeSMatrix(A,B);
DestroySMatrix(A);
DestroySMatrix(B);
case3:
PrinRLSMatrix(A);
求A的转置矩阵B------(一般算法):
TransposeSMatrix(A,B);
DestroySMatrix(B);
求A的转置矩阵B------(快速转置):
\n\n\n\n"
}
printf("
**********请选择是否继续输入其他稀疏矩阵?
**********\n\n"
1是,输入其他矩阵\n"
0否,不输入\n\n"
****************************************************\n\n\n\n\n\n\n\n\n\n"
fflush(stdin);
//清除输入缓存区
j);
}while(j==1);
}
(2)创建矩阵
CreateSMatrix(RLSMatrix&
M)//创建稀疏矩阵M
inti,m,n;
intk,j;
输入矩阵的行数、列数、非零元的个数:
scanf("
%d%d%d"
M.mu,&
M.nu,&
M.tu);
M.data[0].i=0;
for(i=1;
i<
=M.tu;
i++)
j=0;
do
{
j++;
if(j>
3)//控制跳出死循环
本次输入失败!
returnERROR;
按行序输入第%d个非零元素所在的行(1~%d)列(1~%d)值:
i,M.mu,M.nu);
scanf("
m,&
n,&
e);
k=0;
if(m<
1||m>
M.mu||n<
1||n>
M.nu)//行或列超出范围
k=1;
M.data[i-1].i||m==M.data[i-1].i&
&
n<
M.data[i-1].j)
}while(k);
M.data[i].i=m;
M.data[i].j=n;
M.data[i].e=e;
}//endfor
return(OK);
(3)销毁矩阵
voidDestroySMatrix(RLSMatrix&
M)//销毁稀疏矩阵M
M.mu=0;
M.nu=0;
M.tu=0;
(4)遍历矩阵
voidPrinRLSMatrix(RLSMatrixM)//遍历稀疏矩阵M
inti;
稀疏矩阵对应的三元组表为:
行列元素值、\n\n"
%2d%4d%8d\n"
M.data[i].i,M.data[i].j,M.data[i].e);
(5)打印矩阵函数
voidprint(RLSMatrixA)//打印矩阵函数,以通常形式输出矩阵
intk=1,a,b;
稀疏矩阵的通常形式为:
intM[MAXSIZE][MAXSIZE];
for(a=0;
a<
A.mu;
a++)//初始化矩阵M
for(b=0;
b<
A.nu;
b++)
M[a][b]=0;
}
while(k<
=A.tu)
M[A.data[k].i-1][A.data[k].j-1]=A.data[k].e;
k++;
a++)
|"
%d"
M[a][b]);
|\n"
(6)工作区函数,显示程序菜单
voidshowtip()//菜单
*
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 三元 表示 稀疏 矩阵 一般 算法 快速