c语言简单学会链表(2):双向链表

本文详细介绍了双向链表的数据结构,包括如何创建节点、尾插法、头插法、正向及反向遍历,同时讲解了如何在双向链表中删除节点,是C语言学习者掌握链表操作的实用教程。
摘要由CSDN通过智能技术生成

双向链表:

数据结构:

typedef struct doublelist {
    int data; //数据域
    struct doublelist *prev; //指针域,前向指针
    struct doublelist *next; //指针域,后向指针
}DOUBLELIST;

创建一个节点:

DOUBLELIST *CreateList(int data)
{
    DOUBLELIST *P = NULL;
    P = malloc(sizeof(DOUBLELIST));
    if(p == NULL)
    {
        printf("malloc failed\n");
        return 0;
    }
    p->data = data;
    p->prev = NULL;
    P->next = NULL;
    return p;
}

双向链表的尾插:

DOUBLELIST *tail_insert(DOUBLELIST *header, DOUBLELIST *new)
{
    DOUBLELIST *p = header;
    if(NULL != p->next)
    {
        p = p->next;
    }
    p->next = new;
    new->prev = p;
    
}

双向链表的头插:

DOUBLELIST *headinsert(DOUBLELIST *h
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值