深度解析带头节点单链表的增删改查与销毁链表等操作(含算法编写步骤,有完整代码)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 深度解析带头节点单链表的增删改查与销毁链表等操作(含算法编写步骤,有完整代码)

目录


带头节点单链表的结构体

增加节点

算法思路

代码实现

删除节点

算法思路

代码实现

更新节点值

算法思路

代码实现

查找节点值是否存在

算法思路

代码实现

销毁链表

算法思路

代码实现


正文


带头节点单链表的结构体


typedef int ElemType;
typedef struct node
{
    ElemType data;//数据域
    struct node *next;//指针域
}Node;
//头结点:不保存数据 只有两个指针 加一个结点数目
typedef struct linkedlist
{
    Node *first;//指向链表中的第一个数据结点
    Node *last;//指向链表中的最后一个数据结点
    ElemType NodeNum;//结点的数目
    //...根据具体需求 增加其它的成员变量
}List;


增加节点


算法思路


在链表中找到值为x的结点,在它前面插入一个值为a的结点,如果没有找到,就加在最后,将新链表返回。

   step1:创建一个新的结点 把数据写进去

   step2:找到值为x的点

   step3:分情况插入


代码实现


/*
    add_a_node:在链表中找到值为x的结点 在它前面插入值为a的结点,没有则加到最后。
    @list:原来的链表的头结点
    @x:遍历要找到的值
    @a:要插入的结点值
*/
List* add_a_node(List *list, ElemType x, ElemType a)
{
    Node *p = NULL;//遍历指针
    Node *pre = NULL;//指向p前面的那个结点
    Node *pnew = NULL;//指向新创建的结点
    //step1:创建一个新的结点 把数据写进去
    pnew = malloc(sizeof(*pnew));    
    pnew->data = a;
    pnew->next = NULL;
    //step2:找到值为x的点
    p = list->first;
    while(p)
    {   
        if(p->data == x)
        {
            break;
        }
        pre = p;//pre往后移
        p = p->next;//p也往后移
    }
    //step3:分情况插入
    if(p != NULL)//找到了
    {
        if(p == list->first)//头插 
        {
            pnew->next = list->first;
            list->first = pnew;
        }
        else//中间插入
        {
            pnew->next = p;
            pre->next = pnew;
        }
    }
    else//没找到 插尾
    {
        if(list->first == NULL)
        {
            list->first = pnew;
            list->last = pnew;
        }
        else
        {
            list->last->next = pnew;
            list->last = pnew;
        }
    }
    list->NodeNum++;
    return list;
}


删除节点


算法思路


在链表中找到值为x的结点,将其删除,没有找到,就不删除,将新链表返回。

   算法思路:

       step1:遍历 找到值为x的结点

       step2:分情况删除


代码实现


/*
    删:在链表中找到值为x的结点,将其删除,没有找到,就不删除,将新链表返回。
  算法思路:
    step1:遍历 找到值为x的结点
    step2:分情况删除
*/
List *delete_x(List *list, ElemType x)
{
    Node *p = NULL;//遍历指针
    Node *pre = NULL;//指向p前面的那个结点
    p = list->first;
    //step1:遍历 找到值为x的结点
    while(p)
    {
        if(p->data == x)//找到了
        {
            //step2:分情况删除
            if(p == list->first)//要删除的结点为第一个
            {
                list->first = list->first->next;
                p->next = NULL;
                free(p);
                p = list->first;
            }
            else if(p == list->last)//要删的结点为最后
            {
                list->last = pre;
                list->last->next = NULL;
                free(p);
                p = NULL;
            }
            else//要删除的结点为空间
            {
                pre->next = p->next;
                p->next = NULL;
                free(p);
                p = pre->next;
            }
            list->NodeNum--;
        }
        else//没找到 接着往后找
        {
            pre = p;
            p = p->next;
        }
        if(list->NodeNum == 0)
        {
            list->last = NULL;
        }
    }
    return list;
}


更新节点值


算法思路


      把list头结点指向的链表,值为x的结点改为a。

           算法思路:

               遍历找x。

代码实现


/*
    update_node:更新一个链表的值 把x变为a。
    @list: 要更新的链表
    @x:要修改的数据结点的值
    @a: 要更新后数据结点的值
    返回值:
        更新完链表C的头结点
*/
List *update_node(List *list, ElemType x, ElemType a)
{
    Node *p = list->first;
    while(p)
    {
        if(p->data == x)
        {
            p->data = a;
        }
        p = p->next;
    }
    return list;
}


查找节点值是否存在


算法思路


        把list头结点指向的链表,找到链表中是否有值为x的结点。

           算法思路:

               遍历找x。


代码实现


/* 
    find_node:查找一个值是否存在与链表中
     @list: 要更新的链表
    @x:要查找的数据结点的值
    返回值:
        1 该值存在与链表中
        0 该值不存在与链表中
 */
int find_node(List *list,int x)
{
    Node *p = list->first;
    while(p)
    {
        if(p->data == x)
        {
            return 1;
        }
        p = p->next;
    }
    return 0;
}


销毁链表


算法思路

 

       s1: 把数据结点一个个摘除 free掉

       s2:free掉头结点


代码实现


/*
    destory_list: 销毁一个链表
    @list: 要更新的链表
*/
void destory_list(List *list)
{
    Node *p = list->first;
    //s1: 把数据结点一个个摘除 free掉
    while(p)
    {
        list->first = list->first->next;
        p->next = NULL;
        free(p);
        p = list->first;
    }
    //s2:free掉头结点
    list->last = NULL;
    list->NodeNum = 0;
    free(list);  
}


相关文章
|
2月前
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
57 3
|
5天前
|
自然语言处理 搜索推荐 数据安全/隐私保护
鸿蒙登录页面好看的样式设计-HarmonyOS应用开发实战与ArkTS代码解析【HarmonyOS 5.0(Next)】
鸿蒙登录页面设计展示了 HarmonyOS 5.0(Next)的未来美学理念,结合科技与艺术,为用户带来视觉盛宴。该页面使用 ArkTS 开发,支持个性化定制和无缝智能设备连接。代码解析涵盖了声明式 UI、状态管理、事件处理及路由导航等关键概念,帮助开发者快速上手 HarmonyOS 应用开发。通过这段代码,开发者可以了解如何构建交互式界面并实现跨设备协同工作,推动智能生态的发展。
68 10
鸿蒙登录页面好看的样式设计-HarmonyOS应用开发实战与ArkTS代码解析【HarmonyOS 5.0(Next)】
|
21天前
|
机器学习/深度学习 人工智能 算法
深入解析图神经网络:Graph Transformer的算法基础与工程实践
Graph Transformer是一种结合了Transformer自注意力机制与图神经网络(GNNs)特点的神经网络模型,专为处理图结构数据而设计。它通过改进的数据表示方法、自注意力机制、拉普拉斯位置编码、消息传递与聚合机制等核心技术,实现了对图中节点间关系信息的高效处理及长程依赖关系的捕捉,显著提升了图相关任务的性能。本文详细解析了Graph Transformer的技术原理、实现细节及应用场景,并通过图书推荐系统的实例,展示了其在实际问题解决中的强大能力。
119 30
|
25天前
|
存储 算法
深入解析PID控制算法:从理论到实践的完整指南
前言 大家好,今天我们介绍一下经典控制理论中的PID控制算法,并着重讲解该算法的编码实现,为实现后续的倒立摆样例内容做准备。 众所周知,掌握了 PID ,就相当于进入了控制工程的大门,也能为更高阶的控制理论学习打下基础。 在很多的自动化控制领域。都会遇到PID控制算法,这种算法具有很好的控制模式,可以让系统具有很好的鲁棒性。 基本介绍 PID 深入理解 (1)闭环控制系统:讲解 PID 之前,我们先解释什么是闭环控制系统。简单说就是一个有输入有输出的系统,输入能影响输出。一般情况下,人们也称输出为反馈,因此也叫闭环反馈控制系统。比如恒温水池,输入就是加热功率,输出就是水温度;比如冷库,
203 15
|
2月前
|
搜索推荐 算法
插入排序算法的平均时间复杂度解析
【10月更文挑战第12天】 插入排序是一种简单直观的排序算法,通过不断将未排序元素插入到已排序部分的合适位置来完成排序。其平均时间复杂度为$O(n^2)$,适用于小规模或部分有序的数据。尽管效率不高,但在特定场景下仍具优势。
|
25天前
|
存储 算法 C语言
【C语言】深入浅出:C语言链表的全面解析
链表是一种重要的基础数据结构,适用于频繁的插入和删除操作。通过本篇详细讲解了单链表、双向链表和循环链表的概念和实现,以及各类常用操作的示例代码。掌握链表的使用对于理解更复杂的数据结构和算法具有重要意义。
266 6
|
24天前
|
PHP 开发者 容器
PHP命名空间深度解析:避免命名冲突与提升代码组织####
本文深入探讨了PHP中命名空间的概念、用途及最佳实践,揭示其在解决全局命名冲突、提高代码可维护性方面的重要性。通过生动实例和详尽分析,本文将帮助开发者有效利用命名空间来优化大型项目结构,确保代码的清晰与高效。 ####
21 1
|
1月前
|
机器学习/深度学习 存储 人工智能
强化学习与深度强化学习:深入解析与代码实现
本书《强化学习与深度强化学习:深入解析与代码实现》系统地介绍了强化学习的基本概念、经典算法及其在深度学习框架下的应用。从强化学习的基础理论出发,逐步深入到Q学习、SARSA等经典算法,再到DQN、Actor-Critic等深度强化学习方法,结合Python代码示例,帮助读者理解并实践这些先进的算法。书中还探讨了强化学习在无人驾驶、游戏AI等领域的应用及面临的挑战,为读者提供了丰富的理论知识和实战经验。
58 5
|
1月前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
71 4
|
1月前
|
存储 安全 Java
系统安全架构的深度解析与实践:Java代码实现
【11月更文挑战第1天】系统安全架构是保护信息系统免受各种威胁和攻击的关键。作为系统架构师,设计一套完善的系统安全架构不仅需要对各种安全威胁有深入理解,还需要熟练掌握各种安全技术和工具。
146 10

热门文章

最新文章

推荐镜像

更多