用三元组表存储表示,求稀疏矩阵M转置函数T
更新时间:2023-09-28 22:24:01 阅读量: 综合文库 文档下载
实验目的
采用三元组表存储表示,求稀疏矩阵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(m<1||m>(*M).mu||n<1||n>(*M).nu) k=1; if(m<(*M).data[i-1].i||m==(*M).data[i-1].i&&n<(*M).data[i-1].j) k=1; }while(k); (*M).data[i].i=m; (*M).data[i].j=n; (*M).data[i].e=e; } printf(\ return 1; }
//输出稀疏矩阵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等于非零个数,跳出外循环。
正在阅读:
《庖丁解牛》优秀教案教学内容04-17
美国12艘航母09-20
金鹰奖电影获奖名单3篇03-24
学生行为十不准、安全十不准04-22
2014年中考英语试题分类汇编 名词、数词(单选)05-22
2015年河北省公务员考试每日一练题目(11.27)05-23
报关员资格考试报关单填制与查错练习一12-03
城市轨道交通接触轨系统技术规范08-20
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 三元
- 稀疏
- 矩阵
- 函数
- 存储
- 表示
- 3.五月份劳动技能竞赛实施方案
- 高中《世界是永恒发展的》教案说课稿
- 09春计应班理论试卷
- 解决问题的策略2
- 浅谈曾国藩家庭教育思想及对现代家庭教育的启示
- 2015秋季义务教育课程标准实验教科书语文四年级上册期中测试题
- 2016年度中心小学工会工作总结
- 工作部署讲话稿 干部审核工作上的讲话稿 精品
- 2018-2024年中国自旋翼飞机行业市场调研与发展前景分析报告(目录) - 图文
- 植物保护技术(1-4章)
- 2018年信阳市小升初语文模拟试题与答案
- 文言文赏析
- 第29个教师节蔡华讲话稿(初稿)
- 杭州市拱墅区卫生局关于做好医师定期考核工作的通知
- 学案导学设计高中语文苏教版选修《唐诗宋词选读》专题检测:专题四 沉郁顿挫的杜甫诗
- BT项目:理性认识政府回购, 谨慎防范法律风险
- 宏观经济学考试题2
- 焊工初训3
- 高三信息技术(浙江选考)一轮复习: 算法与程序设计 算法的程序实现
- 化学课外兴趣小组活动计划安排、记录、教案