本文介绍: 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
反转链表题目描述
给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。
题解1-迭代
假设链表为 1→2→3→∅,我们想要把它改成 ∅←1←2←3。
在遍历链表时,将当前节点的 next 指针改为指向前一个节点。由于节点没有引用其前一个节点,因此必须事先存储其前一个节点。在更改引用之前,还需要存储后一个节点。最后返回新的头引用。
在上述代码中,prev 并不是直接加入节点的。相反,prev 是用来指向当前节点的前一个节点的。在链表反转过程中,prev 会跟随着 curr 节点向前移动,而 curr 则指向当前正在处理的节点。加入节点的顺序是通过将当前节点的 next 指针指向前一个节点来实现的,从而改变了链表的连接顺序,达到反转链表的效果。
具体来说,在代码中的循环中,每一次迭代都会执行以下操作:
通过不断迭代链表,并在每一步中更新指针的指向,实现了链表的反转。这样,循环结束时,prev
指向的是原链表的尾节点,即新的头节点,完成了链表的反转。
题解2递归
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。