大家好,今天小编关注到一个比较有意思的话题,就是关于c语言链表反转的问题,于是小编就整理了1个相关介绍c语言链表反转的解答,让我们一起看看吧。
有什么好的办法记住链表翻转?
单链表,官方释义为:是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素。链表中的数据是以结点来表示的,每个结点的构成:元素(数据元素的映象) + 指针(指示后继元素存储位置),元素就是存储数据的存储单元,指针就是连接每个结点的地址数据。如图:
单链是单向的,只能单向访问,现需要将链表翻转过来,也就是说next指针要反向。
当然这里有个简单的思路:遍历一遍链表,将每个元素都存储进vector容器,反向迭代vector的每个元素,并将元素的next指针指向容器中前一个元素。这是最简单的方式,实现起来也十分好理解;
但是这种方式并不是鹅厂想要的,因为想考的是面试者对链表数据结构的理解程度,以及逻辑思维的深度。
单链表反转,我们需要处理的就是当前节点、当前节点前一个节点、当前节点后一个节点,这三个节点之间的逻辑关系(node_head、node_temp_pre、node_temp_next)。其实我们只需要将头指针逐步顺着链表往后移,并且在移动过程中,改变next的指向。
思路实现关键点:
首先我们得在改变当前节点next指向之前将next指向的节点访问出来并通过指针保存起来,不然当当前节点的next指向改变再来访问就访问不到了
然后将next指向node_temp_pre(之前保存的前一个节点)
到此,以上就是小编对于c语言链表反转的问题就介绍到这了,希望介绍关于c语言链表反转的1点解答对大家有用。