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

本文涉及的产品
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 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月前
|
前端开发 JavaScript
React 步骤条组件 Stepper 深入解析与常见问题
步骤条组件是构建多步骤表单或流程时的有力工具,帮助用户了解进度并导航。本文介绍了在React中实现简单步骤条的方法,包括基本结构、状态管理、样式处理及常见问题解决策略,如状态管理库的使用、自定义Hook的提取和CSS Modules的应用,以确保组件的健壮性和可维护性。
81 17
|
4月前
|
开发框架 供应链 监控
并行开发模型详解:类型、步骤及其应用解析
在现代研发环境中,企业需要在有限时间内推出高质量的产品,以满足客户不断变化的需求。传统的线性开发模式往往拖慢进度,导致资源浪费和延迟交付。并行开发模型通过允许多个开发阶段同时进行,极大提高了产品开发的效率和响应能力。本文将深入解析并行开发模型,涵盖其类型、步骤及如何通过辅助工具优化团队协作和管理工作流。
134 3
|
3天前
|
传感器 算法 物联网
基于粒子群算法的网络最优节点部署优化matlab仿真
本项目基于粒子群优化(PSO)算法,实现WSN网络节点的最优部署,以最大化节点覆盖范围。使用MATLAB2022A进行开发与测试,展示了优化后的节点分布及其覆盖范围。核心代码通过定义目标函数和约束条件,利用PSO算法迭代搜索最佳节点位置,并绘制优化结果图。PSO算法灵感源于鸟群觅食行为,适用于连续和离散空间的优化问题,在通信网络、物联网等领域有广泛应用。该算法通过模拟粒子群体智慧,高效逼近最优解,提升网络性能。
|
1月前
|
安全 网络协议 应用服务中间件
2025通配符证书免费申请步骤解析
打造安全、高效的网站加密环境,从免费通配符SSL证书开始!今年我们特别推出免费通配符SSL证书申请活动,覆盖主域名及所有子域名。只需一次申请,即可保护无限子域名,节省时间和资源。全程0成本,自动化流程快速配置,权威CA机构签发,兼容主流浏览器与平台。非技术人员也能轻松操作,提升网站安全性与用户信任度。立即访问JoySSL官网注册并申请,享受顶级加密服务!
|
1月前
|
传感器 算法
基于GA遗传优化的WSN网络最优节点部署算法matlab仿真
本项目基于遗传算法(GA)优化无线传感器网络(WSN)的节点部署,旨在通过最少的节点数量实现最大覆盖。使用MATLAB2022A进行仿真,展示了不同初始节点数量(15、25、40)下的优化结果。核心程序实现了最佳解获取、节点部署绘制及适应度变化曲线展示。遗传算法通过初始化、选择、交叉和变异步骤,逐步优化节点位置配置,最终达到最优覆盖率。
|
2月前
|
存储 算法 C语言
【C语言】深入浅出:C语言链表的全面解析
链表是一种重要的基础数据结构,适用于频繁的插入和删除操作。通过本篇详细讲解了单链表、双向链表和循环链表的概念和实现,以及各类常用操作的示例代码。掌握链表的使用对于理解更复杂的数据结构和算法具有重要意义。
768 6
|
4月前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
72 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
5月前
|
机器学习/深度学习 存储 人工智能
让模型评估模型:构建双代理RAG评估系统的步骤解析
在当前大语言模型(LLM)应用开发中,评估模型输出的准确性成为关键问题。本文介绍了一个基于双代理的RAG(检索增强生成)评估系统,使用生成代理和反馈代理对输出进行评估。文中详细描述了系统的构建过程,并展示了基于四种提示工程技术(ReAct、思维链、自一致性和角色提示)的不同结果。实验结果显示,ReAct和思维链技术表现相似,自一致性技术则呈现相反结果,角色提示技术最为不稳定。研究强调了多角度评估的重要性,并提供了系统实现的详细代码。
84 10
让模型评估模型:构建双代理RAG评估系统的步骤解析
|
4月前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
43 0
LeetCode第二十四题(两两交换链表中的节点)
|
4月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
54 0
Leetcode第十九题(删除链表的倒数第N个节点)

推荐镜像

更多