三元组顺序表表示的稀疏矩阵转置(10分)
三元组顺序表表示的稀疏矩阵转置(10分)
本题要求实现一个函数,实现三元组顺序表表示的稀疏矩阵转置。
函数接口定义:#
struct tripletable * trans(struct tripletable *t1);
其中 t1
是用户传入的参数。 函数须返回转置后的三元组顺序表指针。
裁判测试程序样例:#
#include <stdio.h>
#include <stdlib.h>
#define M 100
struct node{
int i,j,v;
};
struct tripletable
{
struct node S[M];
int m,n,t;
};
struct tripletable * create()
{ int i;
struct tripletable *head=(struct tripletable *)malloc(sizeof(struct tripletable));
scanf("%d%d%d",&(head->m),&(head->n),&(head->t));
for(i=0;i<head->t;i++)
scanf("%d%d%d",&(head->S[i].i),&(head->S[i].j),&(head->S[i].v));
return head;
}
void print(struct tripletable * head)
{
int i;
for(i=0;i<head->t;i++)
printf("%d %d %d\n",(head->S[i].i),(head->S[i].j),(head->S[i].v));
}
struct tripletable * trans(struct tripletable *t1);
int main()
{
struct tripletable * head,*t2;
head=create();
t2=trans(head);
print(t2);
return 0;
}
/* 请在这里填写答案 */
输入样例:#
输入第1行为矩阵行数m、列数n及非零元素个数t。 按行优先顺序依次输入t行,每行3个数,分别表示非零元素的行标、列标和值。
3 4 3
0 1 -5
1 0 1
2 2 2
输出样例:#
输出转置后的三元组顺序表结果,每行输出非零元素的行标、列标和值,行标、列标和值之间用空格分隔,共t行。
0 1 1
1 0 -5
2 2 2
代码:#
在这里展现的是包括主函数的程序,自己理解一下转化成为一个函数
#include<stdio.h>
#include<stdlib.h>
#define Maxsize 225
typedef struct
{
int r,c;//行号,列号
int d;//元素值
}TupNode;//三元组类型
typedef struct
{
int m,n;//行数,列数
int t;//非零元素的个数
TupNode data[Maxsize]; //非零元三元组表
}TSMatrix;//三元组顺序表
int main()
{
TSMatrix T;
TSMatrix Tb;
int i,j,x,l,q;
int M,N,S;//输入的行数、列数、非零的个数
scanf("%d %d %d",&M,&N,&S);
int k,kl=0,v;//kl记录Tb中元素的个数
T.m=M;//行数赋值
T.n=N;//列数赋值
T.t=S;//非零元素个数
//输入数据
for(k=0;k<S;k++)
{
scanf("%d %d %d",&T.data[k].r,&T.data[k].c,&T.data[k].d);
}
Tb.m=T.n;//转置矩阵的行数
Tb.n=T.m;//转置矩阵的列数
Tb.t=T.t;//转置矩阵非零元素的个数
//转置//
for(v=0;v<T.n;v++)
{
for(k=0;k<T.t;k++)
{
if(T.data[k].c==v)//找到另一个列号为v的元素
{
Tb.data[kl].r=T.data[k].c;
Tb.data[kl].c=T.data[k].r;
Tb.data[kl].d=T.data[k].d;
kl++;
}
}
}
for(i=0;i<S;i++)
{
printf("%d %d %d\n",Tb.data[i].r,Tb.data[i].c,Tb.data[i].d);
}
}
作者:Evinci
出处:https://www.cnblogs.com/evinci/p/17123986.html
版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律