稀疏矩阵十字链表类java_建立稀疏矩阵的十字链表

这篇博客介绍了如何使用C语言创建稀疏矩阵的十字链表数据结构。通过读取矩阵的行数、列数及非零元素数量,利用动态内存分配创建十字链表,并实现了按行和列有序插入元素的功能。
摘要由CSDN通过智能技术生成

[c]代码库typedef struct node

{

int row, col;

struct node *down , *right;

union v_next

{

datatype v;

struct node *next;

}

} MNode,*MLink;

MLink CreatMLink( ) /* 返回十字链表的头指针*/

MLink H;

Mnode *p,*q,*hd[s+1];

int i,j,m,n,t;

datatype v;

scanf ( “%d,%,%d”,&m,&n,&t );

H=malloc ( sizeof ( MNode ) ); /*申请总头结点*/

H->row=m;

H->col=n;

hd[0]=H;

for ( i=1; i

{

p=malloc ( sizeof ( MNode ) ); /*申请第i 个头结点*/

p->row=0;

p->col=0;

p->right=p;

p->down=p;

hd[i]=p;

hd[i-1]->v_next.next=p;

}

hd[S]->v_next.next=H; /*将头结点们形成循环链表*/

for ( k=1; k<=t; k++ )

{

scanf ( “%d,%d,%d”,&i,&j,&v ); /*输入一个三元组,设值为int*/

p=malloc ( sizeof ( MNode ) );

p->row=i ;

p->col=j;

p->v_next.v=v

/*以下是将*p 插入到第i 行链表中去,且按列号有序*/

q=hd[i];

while ( q->right!=hd[i] && ( q->right->col )

q=q->right;

p->right=q->right; /*插入*/

q->right=p;

/*以下是将*p 插入到第j 行链表中去,且按行号有序*/

q=hd[i];

while ( q->down!=hd[j] && ( q->down->row )

q=q->down;

p-> down =q-> down; /*插入*/

q-> down =p;

} /*for k*/

return H;

} /* CreatMLink */

694748ed64b9390909c0d88230893790.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值