题目:剑指 Offer 24. 反转链表
定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL
限制:0 <= 节点个数 <= 5000
链接:https://leetcode-cn.com/problems/fan-zhuan-lian-biao-lcof
解题:
/**
解题思路:
方法一:迭代
假设链表为 1→2→3→∅,我们想要把它改成 ∅←1←2←3。
在遍历链表时,将当前节点的next 指针改为指向前一个节点。由于节点没有引用其前一个节点,因此必须事先存储其前一个节点。在更改引用之前,还需要存储后一个节点。最后返回新的头引用。
*/
public static ListNode reverseList(ListNode head) {
if (head == null || head.next == null) {
return head;
}
ListNode perNode = null;
ListNode curNode = head;
while (curNode != null) {
ListNode tem = curNode.next;
curNode.next = perNode;
perNode = curNode;
curNode = tem;
}
return perNode;
}