反转一个单链表。java
Reverse a singly linked list.python
示例:函数
输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL
进阶: 你能够迭代或递归地反转链表。你可否用两种方法解决这道题?code
Follow up:对象
A linked list can be reversed either iteratively or recursively. Could you implement both?递归
每次遍历到最后一位取节点这种方法就算了时间复杂度过高。如题目进阶要求的两种方法,迭代和递归:it
每次分出来一个节点把节点做为头节点添加到新链表上:io
原链表:1->2->3->4->5class
分离第一个节点做为头节点添加到新链表:1 原链表:2->3->4->5原理
分离下一个节点做为头节点添加到新链表:2->1 原链表:3->4->5
分离下一个节点做为头节点添加到新链表:3->2->1 原链表:4->5
分离下一个节点做为头节点添加到新链表:4->3->2->1 原链表:5
分离下一个节点做为头节点添加到新链表:5->4->3->2->1 原链表:null
Java:
class Solution { public ListNode reverseList(ListNode head) { if (head == null || head.next == null) return head; ListNode pre = null; ListNode tmp = null; while (head != null) { tmp = head.next;//tmp暂存当前节点的下一个节点 head.next = pre;//当前节点下一个指向pre pre = head;//刷新pre head = tmp;//刷新当前节点为tmp } return pre; } }
Python3:
class Solution: def reverseList(self, head: ListNode) -> ListNode: if not head or not head.next: return head pre,tmp=None,None while(head): tmp=head.next head.next=pre pre=head head=tmp return pre
其实就是用递归完成栈的功能:先进后出
基线条件为遇到空节点(到链表末尾),返回对象为链表的最后一个节点,在递归函数中传递一直不变。从链表末尾向头部逐个分离节点,并将节点添加到新链表的末尾。与迭代法原理类似。
原链表:1->2->3->4->5
递归到最后一层时遇到null节点返回尾节点5
回到上一层递归 分离节点 5 做为新链表的尾节点:5,置空本来5节点,原链表1->2->3->4->null
回到上一层递归 分离节点 4 做为新链表的尾节点:5->4,置空本来4节点,原链表1->2->3->null
回到上一层递归 分离节点 3 做为新链表的尾节点:5->4->3,置空本来3节点,原链表1->2->null
回到上一层递归 分离节点 2 做为新链表的尾节点:5->4->3->2,置空本来2节点,原链表1->null
回到上一层递归 分离节点 1 做为新链表的尾节点:5->4->3->2->1,置空本来1节点,原链表null
Java:
class Solution { public ListNode reverseList(ListNode head) { //基线条件 if (head == null || head.next == null) return head; //递归 ListNode tmp = head.next;//暂存头节点的下一个节点 ListNode pre = reverseList(head.next);//递归调用该函数,pre为返回的新链表的头节点,原链表的最后一个节点,不管递归多少层该返回值一直传递不变 tmp.next = head;//暂存的下一个节点指向传入节点 head.next = null;//下一个节点即本来指向tmp的节点 置空 return pre; } }
Python3:
class Solution: def reverseList(self, head: ListNode) -> ListNode: if not head or not head.next: return head tmp = head.next pre = self.reverseList(head.next) tmp.next = head head.next = None return pre
欢迎关注公.众号一块儿刷题:爱写Bug