【数据结构3】带头指针·单向链表实现

目录

一、带头指针的链表头结构

二、接口的设计与实现

[2.1 在栈上申请空间(init接口实现初始化)](#2.1 在栈上申请空间(init接口实现初始化))

[2.2 头插接口实现](#2.2 头插接口实现)

[2.3 带头指针链表任意位置插入](#2.3 带头指针链表任意位置插入)

[2.4 带头指针链表删除元素](#2.4 带头指针链表删除元素)

[2.5 带头指针链表遍历](#2.5 带头指针链表遍历)

[2.6 销毁元素](#2.6 销毁元素)

三、test测试例


一、带头指针的链表头结构

复制代码
C

// 链表头结构
typedef struct
{
    Node_t *header;
    int count;
}ChainList_t;

二、接口的设计与实现

复制代码
C

void initChainList(ChainList_t *table);

void destroyChianList(ChainList_t *table);   

int insertChainLiHeader(ChainList_t *table,Element_t val);
int insertChainListPos(ChainList_t *table,int pos,Element_t val);

int deleteChainListElement(ChainList_t *table,Element_t val);

void showChianList(const ChainList_t *table);
2.1 在栈上申请空间(init接口实现初始化)
复制代码
C

void initChainList(ChainList_t* table)
{
    table->count = 0;
    table->header = NULL;
}
2.2 头插接口实现

带头指针的链表:引入dummy作为虚拟头结点,简化操作

复制代码
C

int insertChainLiHeader(ChainList_t* table, Element_t val)
{
    Node_t dummy;
    dummy.next = table->header;  // 指针赋值
    //下同,dummy作为虚拟头节点
    Node_t *p = &dummy;

    Node_t *new_node = malloc(sizeof(Node_t));
    if (new_node == NULL)
    {
        return -1;
    }
    // 初始化
    new_node->val = val;
    // 节点插入逻辑
    new_node->next = p->next;
    p->next = new_node;

    ++table->count;

    table->header = dummy.next;  //临时dummy存的值,最后要赋值给头指针

    return 0;
}
2.3 带头指针链表任意位置插入
复制代码
C

int insertChainListPos(ChainList_t* table,int pos, Element_t val)
{
    Node_t dummy;
    dummy.next = table->header;

    // 边界值
    if (pos < 0 || pos > table->count)
    {
        printf("insert pos invalid\n");
        return -1;
    }
    
    Node_t *p = &dummy;
    int index = -1;
    while (index < pos-1)  // index == pos-2、p = p->next退出while
    {
        p = p->next;
        ++index;
    }
    if (p == NULL)
    {
        return -1;
    }
    Node_t *new_node = malloc(sizeof(Node_t));
    new_node->val = val;
    new_node->next = p->next;
    p->next = new_node;

    ++table->count;

    table->header = dummy.next;

    return 0;
}
2.4 带头指针链表删除元素
复制代码
C

int deleteChainListElement(ChainList_t* table, Element_t val)
{
    Node_t dummy;
    dummy.next = table->header;

    Node_t *p = &dummy;

    while (p->next && p->next->val != val)
    {
        p = p->next;
    }
    if (p->next == NULL)
    {
        printf("not find\n");
        return -1;
    }
    Node_t *tmp = p->next;
    p->next = tmp->next;
    free(tmp);
    --table->count;

    table->header = dummy.next;

    return 0;

}
2.5 带头指针链表遍历
复制代码
C

void showChianList(const ChainList_t* table)
{
    // p指向第一个节点(比如100)
    Node_t *p = table->header;
    printf("chainlist : %d Element\n",table->count);

    while (p)
    {
        printf("%d\t",p->val);
        p = p->next;
    }
    printf("\n");
}
2.6 销毁元素

销毁该链表的元素区域,头不管(在堆上申请的空间才需要手动申请和释放)

复制代码
C

void destroyChianList(ChainList_t *table)
{
    Node_t dummy;
    dummy.next = table->header;

    Node_t *p = &dummy;
    Node_t *tmp;
    while (p->next)
    {
        tmp = p->next;
        p->next = tmp->next;
        free(tmp);
        --table->count;
    }
    printf("chainlist have : %d element",table->count);
}

三、test测试例

复制代码
C

int test02()
{
    ChainList_t table1;  //表在栈上
    initChainList(&table1); //进行初始化,而非创建新表
    for (int i=0;i<10;i++)
    {
        insertChainLiHeader(&table1,i+200);
    }
    insertChainListPos(&table1,8,7000);
    showChianList(&table1);
    deleteChainListElement(&table1,200);

    showChianList(&table1);

    destroyChianList(&table1);  
}

如果我的内容对你有帮助,请点赞,评论,收藏。创作不易,大家的支持就是我坚持下去的动力!

相关推荐
郝学胜-神的一滴6 小时前
二叉树与递归:解锁高级数据结构的编程内功心法
开发语言·数据结构·c++·算法·面试
AI机器学习算法6 小时前
说走就走的AI之旅第01课:浅谈机器学习
数据结构·人工智能·python·深度学习·机器学习·大模型·线性回归
csdn_aspnet6 小时前
C++ (Naive Partition Algorithm)朴素划分算法
数据结构·c++·算法
酿情师6 小时前
区块链原理与技术02:UTXO 模型、账户余额模型与以太坊账户体系(区块链的数据结构03)
数据结构·区块链
薇茗7 小时前
【初阶数据结构】 左右逢源的分支诗律 二叉树3
c语言·数据结构·二叉树·经典oj面试题
洛水水7 小时前
【力扣100题】20.合并 K 个升序链表
算法·leetcode·链表
夏日听雨眠16 小时前
数据结构(栈和队列)
数据结构
流年如夢19 小时前
栈和列队(LeetCode)
数据结构·算法·leetcode·链表·职场和发展
qeen871 天前
【数据结构】二叉树相关经典函数C语言实现
c语言·数据结构·c++·笔记·学习·算法·二叉树
良木生香1 天前
【C++初阶】STL——List从入门到应用完全指南(1)
开发语言·数据结构·c++·程序人生·算法·蓝桥杯·学习方法