24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 864  |  回复: 1

lelemaoer

金虫 (初入文坛)

[求助] 请教《数据结构》,建立稀疏矩阵的十字链表算法。

#include
#include

typedef int ElementType;
typedef struct OLNode /*十字链表的结构类型定义如下:*/
{
        int row,col; /*非零元素的行和列下标*/
        ElementType value;
        struct OLNode *right,*down; /*非零元素所在行表、列表的后继链域*/
}OLNode,*OLink;

typedef struct
{
        OLink *row_head,*col_head; /*行、列链表的头指针向量*/
        int m,n,len; /*稀疏矩阵的行数、列数、非零元素的个数*/
}CrossList;


void CreateCrossList(CrossList *M)
{
        int m,n,t;
        OLNode *p,*q;
        int i,j,e,k;

        printf("输入M的行数,列数,和非零元的个数:"; /*采用十字链表存储结构,创建稀疏矩阵M*/
        scanf("%d,%d,%d",&m,&n,&t); /*输入M的行数,列数和非零元素的个数*/
        M->m=m;
        M->n=n;
        M->len=t;
        if( !(M->row_head=(OLink*)malloc( (m+1)*sizeof(OLink)) ))
                printf("error";
        if( !(M->col_head=(OLink *)malloc( (n+1)*sizeof(OLink)) ))
                printf("error";

        for(k=1;k<=m;k++)
                M->row_head[k]=NULL;
        for(k=1;k<=n;k++)
                M->col_head[k]=NULL; /*初始化行、列头指针向量,各行、列链表为空的链表*/
               
        printf("输入各非零元素行,列和值,逗号隔开!\n";
        for( scanf("%d,%d,%d",&i,&j,&e);i!=0;scanf("%d,%d,%d",&i,&j,&e) )
        {
                if( !(p=(OLNode *)malloc(sizeof(OLNode))) )
                        printf("error";
                p->row=i;
                p->col=j;
                p->value=e;

                if(M->row_head==NULL) /*生成结点*/
                        M->row_head=p;
                else /*寻找行表中的插入位置*/
                {
                        for(q=M->row_head; q->right&&q->right->colright); /*空循环体*/
                        p->right=q->right;
                        q->right=p; /*完成插入*/
                }

                if(M->col_head[j]==NULL)
                        M->col_head[j]=p;
                else /*寻找列表中的插入位置*/
                {
                        for(q=M->col_head[j]; q->down&&q->down->rowdown); /*空循环体*/
                        p->down=q->down;
                        q->down=p; /*完成插入*/
                }
        }
}


main()
{
        CrossList M;
        CreateCrossList(&M);
}
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yalefield

金虫 (文坛精英)

老汉一枚

中麻辣?
2楼2012-07-10 15:22:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 lelemaoer 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿郑州大学材料与化工085600,求调剂 +10 吃的不少 2026-04-02 10/500 2026-04-02 22:58 by 马儿快快地跑
[考研] 085600,320分求调剂 +6 大馋小子 2026-04-02 6/300 2026-04-02 21:54 by dongzh2009
[考研] 工科 267求调剂 +3 wanwan00 2026-04-02 5/250 2026-04-02 21:42 by wanwan00
[考研] +4 雾与海 2026-04-02 5/250 2026-04-02 19:16 by 土木硕士招生
[考研] 化学308分调剂 +14 你好明天你好 2026-03-30 15/750 2026-04-02 13:39 by 嘻嘻笑22
[考研] 材料求调剂 一志愿哈工大总分298分,前三科223分 +12 dongfang59 2026-03-27 12/600 2026-04-02 12:26 by ms629
[考研] 085600,材料与化工321分,求调剂 +13 大馋小子 2026-03-27 13/650 2026-04-02 10:48 by sanrepian
[考研] 372求调剂 +3 jj涌77 2026-04-02 3/150 2026-04-02 09:57 by olim
[考研] 生物学327,求调剂 +5 书上的梅子 2026-04-01 6/300 2026-04-02 06:47 by ilovexiaobin
[考研] 材料专硕调剂 +17 椰椰。 2026-03-29 17/850 2026-04-01 20:44 by cq2548
[考研] 353求调剂 +4 拉钩不许变 2026-04-01 4/200 2026-04-01 18:10 by 记事本2026
[考研] 本2一志愿C9-333分,材料科学与工程,求调剂 +9 升升不降 2026-03-31 9/450 2026-03-31 18:01 by 无际的草原
[考研] 346求调剂 一志愿070303有机化学 +11 萝卜炖青菜 2026-03-28 12/600 2026-03-31 17:54 by xhai2011
[考研] 材料工程专硕求调剂 +10 hyl3153942 2026-03-29 10/500 2026-03-31 16:31 by hypershenger
[考研] 262求调剂 +7 ZZ..000 2026-03-30 8/400 2026-03-31 10:05 by cal0306
[考研] 调剂 +4 GK72 2026-03-30 4/200 2026-03-30 20:32 by dick_runner
[考研] 328求调剂 +8 嗯滴的基本都 2026-03-27 8/400 2026-03-30 17:20 by Wang200018
[考研] 材料与化工(0856)304求B区调剂 +8 邱gl 2026-03-27 8/400 2026-03-28 12:42 by 唐沐儿
[考研] 272求调剂 +7 脚滑的守法公民 2026-03-27 7/350 2026-03-27 17:23 by laoshidan
[考研] 298调剂 +3 jiyingjie123 2026-03-27 3/150 2026-03-27 11:57 by wxiongid
信息提示
请填处理意见