双向链表,还能这么实现

本文探讨了如何在C语言中实现双向链表,通过引入哨兵节点和构造环形结构来避免对NULL的判断,简化代码。文章详细介绍了改进方案,包括数据结构的调整、初始化过程以及增删节点的方法,旨在提供一种更高效、简洁的双向链表实现策略。
摘要由CSDN通过智能技术生成

双向链表,是一种常用的数据结构。在C语言中,双向链表的实现,通常采用下面的数据结构:

typedef struct dlist_node_t {
    struct dlist_node_t* pprev;
    struct dlist_node_t* pnext;
    void* pdata;
} dlist_node_t;

typedef struct dlist_t {
    dlist_node_t* phead;
    dlist_node_t* ptail;
} dlist_t;

dlist_t 是双向链表的数据结构,其有两个指针:一个指向头部节点,一个执行尾部节点。
每个节点,用dlist_node_t来表示,节点内部有三个成员:指向前一个节点的指针,指向下一个节点的指针,节点保存的数据指针。

向链表增加或删除节点时,都需要对指针是否为NULL进行判断,包括:判断dlist_t的头指针、尾指针是否为NULL,判断dlist_node_t的前向、后向指针是否为NULL,从而进行对应的处理,这样排列组合起来的场景是比较多的,因此代码实现逻辑比较繁琐。

 

为了避免判断NULL,简化代码,一些新的实现思路被提出。

有人提议,把dlist_t的头尾指针,都改成dlist_node_t结构体,形成2个固定的哨兵,如下:

typedef struct dlist_t {
    dlist_node_t head;
    dlist_node_t tail;
} dlist_t;</
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值