leetcode——Java反转链表

206. 反转链表

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

遍历法

遍历法就是在链表遍历的过程中将指针顺序置换

leetcode——Java反转链表_第1张图片

 

leetcode——Java反转链表_第2张图片

输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

leetcode——Java反转链表_第3张图片

输入:head = [1,2]
输出:[2,1] 

示例 3:

输入:head = []
输出:[]

思路:

方法一:迭代
假设链表为 1 1→2→3→∅,我们想要把它改成  ∅←1←2←3。

在遍历链表时,将当前节点的 \textit{next}next 指针改为指向前一个节点。由于节点没有引用其前一个节点,因此必须事先存储其前一个节点。在更改引用之前,还需要存储后一个节点。最后返回新的头引用。

leetcode——Java反转链表_第4张图片

 leetcode——Java反转链表_第5张图片

 leetcode——Java反转链表_第6张图片

public class ReverseNode {
    //反转链表  运用迭代法 因为头节点之前为空 所以需要提前设计一个空指针
        public ListNode reverseList(ListNode head) {
            ListNode prev = null;
            ListNode curr = head;
            while (curr != null){
                ListNode next = curr.next;
                curr.next = prev;
                prev = curr;
                curr = next;
            }
            return prev;
            }
        }

依旧是1->2->3->4

  • 准备两个空结点 pre用来保存先前结点、next用来做临时变量
  • 在头结点node遍历的时候此时为1结点
    • next = 1结点.next(2结点)
    • 1结点.next=pre(null)
    • pre = 1结点
    • node = 2结点
  • 进行下一次循环node=2结点
    • next = 2结点.next(3结点)
    • 2结点.next=pre(1结点)=>即完成2->1
    • pre = 2结点
    • node = 3结点
  • 进行循环...

你可能感兴趣的:(leetcode,JAVA,链表,链表,leetcode,java)