iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言单链表实例分析
  • 880
分享到

C语言单链表实例分析

2023-06-30 00:06:19 880人浏览 泡泡鱼
摘要

今天小编给大家分享一下C语言单链表实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、移除链表元素链接直达:移除链表元

今天小编给大家分享一下C语言链表实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

1、移除链表元素

链接直达:

移除链表元素

题目:

C语言单链表实例分析

思路:

此题要综合考虑多种情况,常规情况就如同示例1,有多个节点,并且val不连续,但是非常规呢?当val连续呢?当头部就是val呢?所以要分类讨论

常规情况:

需要定义两个指针prev和cur,cur指向第一个数据,prev指向cur的前一个。依次遍历cur指向的数据是否为val,若是,则把prev的下一个节点指向cur的下一个节点上,cur=cur->next,prev跟着cur一起走,直到cur走到NULL

C语言单链表实例分析

连续val:

当我们仔细观察下,不难发现,在常规情况下是可以解决连续val的,但是头部val就不可了

头部val:

此时除了刚才定义的两个指针prev和cur外,还要有个head指向头部,当头部是val时,将cur指向下一个位置,head跟着一起动,直到cur指向的数据不为val时,将head赋给prev。此时剩余的就按常规处理即可。

C语言单链表实例分析

代码如下:

struct Listnode* removeElements(struct ListNode* head, int val){    struct ListNode*cur=head;    struct ListNode*prev=NULL;    while(cur)    {        if(cur->val!=val)        {            prev=cur;            cur=cur->next;        }        else        {            struct ListNode*next=cur->next;            if(prev==NULL)            {                free(cur);                cur=next;                head=next;            }            else            {                prev->next=cur->next;                free(cur);                cur=prev->next;            }        }    }    return head;}

2、反转链表

链接直达:

反转链表

题目:

C语言单链表实例分析

思路:

法一:三指针翻转方向

定义三个指针n1,n2,n3分别用来指向NULL,第一个数据,第二个数据。让n2的next指向n1,把n2赋给n1,再把n3赋给n2,再执行n3=n3->next的操作,接下来重复上述操作,直到n2指向空即可。但是要注意,要先判断该链表是否为NULL,如果是,则返回NULL,此外,还要保证当n3为空时就不要动了,直接把n3赋给n2即可。

C语言单链表实例分析

代码如下:

struct ListNode* reverseList(struct ListNode* head){    if(head==NULL)    {        return NULL;    }    struct ListNode*n1=NULL;    struct ListNode*n2=head;    struct ListNode*n3=n2->next;    while(n2)    {        n2->next=n1;        n1=n2;        n2=n3;        if(n3)        {            n3=n3->next;        }    }    return n1;}

法二:头插

此法就需要再创建一个链表了,创建一个新的头部newhead指向NULL,再定义一个指针cur指向原链表第一个数据,注意还得定义一个指针next指向cur的下一个节点。遍历原链表,把节点取下来头插到newhead所在的链表。每次更新newhead赋给cur,如图所示:

C语言单链表实例分析

 代码如下:

struct ListNode* reverseList(struct ListNode* head){    if(head==NULL)    {        return NULL;    }    struct ListNode*cur=head;    struct ListNode*next=cur->next;    struct ListNode*newhead=NULL;    while(cur)    {        cur->next=newhead;        newhead=cur;        cur=next;        if(next)        {            next=next->next;        }    }    return newhead;}

3、链表的中间节点

链接直达:

链表的中间节点

题目:

C语言单链表实例分析

 思路:

快慢指针

这道题要注意奇偶数,如果为奇数,如示例1,那么中间节点值就是3,反之偶数如示例2,返回第二个中间节点。此题我们定义两个指针slow和fast都指向第一个数据的位置,区别在于让slow一次走1步,fast一次走2步。当fast走到尾指针时,slow就是中间节点

C语言单链表实例分析

 代码如下:

struct ListNode* middleNode(struct ListNode* head){    struct ListNode*slow=head;    struct ListNode*fast=head;    while(fast&&fast->next)    {        slow=slow->next;        fast=fast->next->next;    }    return slow;}

4、链表中倒数第k个节点

链接直达:

链表中倒数第k个节点

题目:

C语言单链表实例分析

 思路:

快慢指针

定义两个指针slow和fast,让fast先走k步,再让slow和fast同时走,当fast走到尾部时,slow就是倒数第k个,因为这样的话slow和fast的差距始终是k个,当fast走到空时结束。此题同样可以走k-1步,不过当fast走到尾部时结束,也就是fast的下一个节点指向空时结束,都一样。先拿走k步举例,如图所示:

C语言单链表实例分析

 代码如下:

struct ListNode* FindKthToTail(struct ListNode* pListHead, int k ) {    // write code here    struct ListNode*fast=pListHead;    struct ListNode*slow=pListHead;    while(k--)    {        //if判断,防止k大于链表的长度        if(fast==NULL)            return NULL;        fast=fast->next;    }    while(fast)    {        fast=fast->next;        slow=slow->next;    }    return slow;}

5、合并两个有序链表

链接直达:

合并两个有序链表

题目:

C语言单链表实例分析

 思路:

法一:归并(取小的尾插)--- 带头节点

假设新链表的头叫head并指向NULL,还需要定义一个指针tail来方便后续的找尾,依次比较list1和list2节点的值,把小的放到新链表head上,并更新tail,再把list1或list2更新一下。当list1和list2两个链表中一个走到空时,直接把剩下的链表所有剩下的元素拷进去即可

C语言单链表实例分析

 代码如下:

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){    //检查list1或list2一开始就为NULL的情况    if(list1==NULL)    {        return list2;    }    if(list2==NULL)    {        return list1;    }    struct ListNode*head=NULL;    struct ListNode*tail=head;    while(list1&&list2)    {        if(list1->val<list2->val)        {            if(tail==NULL)            {                head=tail=list1;            }            else            {                tail->next=list1;                tail=list1;            }            list1=list1->next;        }        else        {            if(tail==NULL)            {                head=tail=list2;            }            else            {                tail->next=list2;                tail=list2;            }            list2=list2->next;        }    }    //当list1和list2其中一个走到空的情况    if(list1==NULL)    {        tail->next=list2;    }    else    {        tail->next=list1;    }    return head;}

法二:哨兵位的头节点

解释下带头节点:

比如说同样一个链表存1,2,3。不带头节点只有这三个节点,head指向1。而带头节点的同样存3个值,不过有4个节点,head指向头部这个节点,这个节点不存储有效数据

C语言单链表实例分析

 带头结点有如下好处,不用判断head和tail是否为空了,也不用判断list1和list2是否为空了,会方便不少。和上述思路一样,取小的下来尾插,直接链接到tail后面即可。但是要注意返回的时候要返回head的next,因为题目给的链表是不带头的,而head本身指向的就是那个头,所以要返回下一个。

代码如下:

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2) {    struct ListNode* head = NULL, * tail = NULL;    head = tail = (struct ListNode*)malloc(sizeof(struct ListNode));    head->next = NULL;    while (list1 && list2)    {        if (list1->val < list2->val)        {            tail->next = list1;            tail = list1;            list1 = list1->next;        }        else        {            tail->next = list2;            tail = list2;            list2 = list2->next;        }    }    //当list1和list2其中一个走到空的情况    if (list1 == NULL)    {        tail->next = list2;    }    else    {        tail->next = list1;    }    struct ListNode* list = head->next;    free(head);    head = NULL        return list;}

6、链表分割

链接直达:

链表分割

题目:

C语言单链表实例分析

 思路:

定义两个链表lesshead和greaterhead。遍历原链表,把 < x 的插入到链表1,把 > x 的插入到链表2,最后再把链表1和链表2链接起来。在定义两个尾指针以跟进链表1和2新增元素

C语言单链表实例分析

 代码如下:

class Partition {public:    ListNode* partition(ListNode* pHead, int x) {        // write code here        struct ListNode* lessHead, * lessTail, * greaterHead, * greaterTail;        lessHead = lessTail = (struct ListNode*)malloc(sizeof(struct ListNode));        greaterHead = greaterTail = (struct ListNode*)malloc(sizeof(struct ListNode));        lessTail->next = greaterTail->next = NULL;        struct ListNode* cur = pHead;        while (cur)        {            if (cur->val < x)            {                lessTail->next = cur;                lessTail = lessTail->next;            }            else            {                greaterTail->next = cur;                greaterTail = greaterTail->next;            }            cur = cur->next;        }        //合并        lessTail->next = greaterHead->next;        greaterTail->next = NULL;        struct ListNode* list = lessHead->next;        free(lessHead);        free(greaterHead);        return list;    }};

以上就是“C语言单链表实例分析”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网其他教程频道。

--结束END--

本文标题: C语言单链表实例分析

本文链接: https://www.lsjlt.com/news/326810.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • C语言单链表实例分析
    今天小编给大家分享一下C语言单链表实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、移除链表元素链接直达:移除链表元...
    99+
    2023-06-30
  • C语言中单链表的示例分析
    这篇文章将为大家详细讲解有关C语言中单链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、思路步骤1. 定义结构体a.数据域:用来存放数据b.指针域:用来存放下一个数据的位置2.初始化申请头结...
    99+
    2023-06-25
  • C语言链表与单链表详解
    链表是什么及链表的优势 链表是一种介于数组的另外一种数据结构: 我们知道数组可以存放很多的元素,这些元素都是呈线性排列,也就是一个挨着一个连续存放 但是当元素足够多时,还能继续正常的...
    99+
    2024-04-02
  • C语言中单链表如何实现
    这篇文章主要介绍“C语言中单链表如何实现”,在日常操作中,相信很多人在C语言中单链表如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C语言中单链表如何实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧...
    99+
    2023-07-04
  • C语言单双线性及循环链表与实例
    目录链表思维顺序存储结构单链表单链表存储结构 单链表的读取单链表的插入 单链表的删除 单链表的整表创建 头插法建立单链表尾插法建立单链表单链表...
    99+
    2023-03-24
    C语言单双链表 C语言循环链表
  • C语言数据结构之单向链表详解分析
    链表的概念:链表是一种动态存储分布的数据结构,由若干个同一结构类型的结点依次串连而成。 链表分为单向链表和双向链表。 链表变量一般用指针head表示,用来存放链表首结点的地址。 每个...
    99+
    2024-04-02
  • C语言实现单链表的基本操作分享
    目录导语单链表单链表的特点定义初始化操作头插法尾插法删除第i个元素在第i个位置插入导语 无论是顺序存储结构还是链式存储结构,在内存中进行存放元素的时候,不仅需要存放该元素的相关信息,...
    99+
    2022-11-13
    C语言单链表基本操作 C语言单链表
  • 详解C语言之单链表
    目录一、思路步骤1. 定义结构体2.初始化3.求当前数据元素的个数4.插入5.删除6.释放内存空间二、代码总结 一、思路步骤 1. 定义结构体 a.数据域:用来存放数据 b.指针域...
    99+
    2024-04-02
  • C语言单链表的图文示例讲解
    目录一、单链表的结构二、单链表的函数接口1. 申请结点及打印单链表2. 尾插尾删3. 头插头删4. 中间插入和删除1. 在 pos 指向的结点之后插入结点2. 在 pos 指向的结点...
    99+
    2023-02-14
    C语言单链表的基本操作 C语言单链表
  • c语言单链表怎么写
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-05-21
  • C语言经典顺序表实例分析
    这篇“C语言经典顺序表实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言经典顺序表实例分析”文章吧。1、移除元素题...
    99+
    2023-06-30
  • C语言数据结构实例讲解单链表的实现
    目录1、单链表2、单链表的实现头文件函数的实现(1)打印链表(2)动态申请结点(3)尾插(4)头插(5)尾删(6)头删(7)查找(8)在pos之前插入(9)删除pos(10)在pos...
    99+
    2024-04-02
  • C语言链表详解及代码分析
    目录什么是链表环境构建建立静态链表包含所需要的头文件宏定义相关变量创建一个结构体主函数结果展示说明建立动态链表包含所需要的头文件宏定义相关变量创建一个结构体建立链表函数主函数结果展示...
    99+
    2024-04-02
  • C语言如何实现单链表操作
    本篇内容介绍了“C语言如何实现单链表操作”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1 链表的概念及结构概念:链表是一种物理存储结构上非连...
    99+
    2023-06-29
  • C语言实现无头单链表详解
    目录链表的结构体描述(节点)再定义一个结构体(链表) 断言处理 & 判空处理创建链表创建节点头插法打印链表尾插法 指定位置插入 头删法尾删法&n...
    99+
    2024-04-02
  • C语言实现无头单向链表的示例代码
    目录一、易错的接口实现 1.1 新节点开辟函数 1.2 尾插 1.3 尾删 二、常见简单接口 2.1 打印链表 2.2 节点计数器 2.3 判断是否为空链表 2.4 通过值查找节点 ...
    99+
    2024-04-02
  • C++编程语言实现单链表详情
    目录一、单链表简单介绍二、下面我们先实现单链表的初始化。 三、实现单链表的插入与删除数据一、单链表简单介绍 首先,我们再回顾一下线性表的两种存储方式——顺序存储与链式存储 上图左边...
    99+
    2024-04-02
  • C语言中链接器的示例分析
    小编给大家分享一下C语言中链接器的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 什么是链接器典型的链接器把由编译器或汇编器生成的若干个目标模块,整合成...
    99+
    2023-06-29
  • C语言中链表与单链表有什么用
    这篇文章将为大家详细讲解有关C语言中链表与单链表有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。链表是什么及链表的优势链表是一种介于数组的另外一种数据结构:我们知道数组可以存放很多的元素,这些元素都...
    99+
    2023-06-29
  • C语言分支语句实例分析
    这篇文章主要介绍了C语言分支语句实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C语言分支语句实例分析文章都会有所收获,下面我们一起来看看吧。C语言的语句C语句可分为以下五类: 表达式语句 函数调用语句 ...
    99+
    2023-06-30
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作