/* public class ListNode { int val; ListNode next = null; ListNode(int val) { this.val = val; } }*/ public class Solution { public ListNode ReverseList(ListNode head) { //如果链表为空或者只有一个节点,则无需进行反转,直接返回 if(head == null || head.next==null){ return head; } ListNode reverseHead = new ListNode(0);//定义一个虚拟的头节点 ListNode cur = head; ListNode next = null; //本质是头插法 while(cur!=null){ next = cur.next;//保存当前节点的下一个节点,因为当前节点的next指向会被后续的操作改变 cur.next = reverseHead.next;//将虚拟头节点的下一节点挂到新插入的节点的后面 reverseHead.next = cur;//将这个新节点再挂到虚拟头节点的后面 cur = next;//移动cur指针 } return reverseHead.next; } }
变形:反转指定索引段的链表。
来源于LeetCode。
方法一:
将需要反转的部分链表元素截取出来,进行反转,然后在与原来的拼接起来。
// 因为头节点有可能发生变化,使用虚拟头节点可以避免复杂的分类讨论 ListNode dummyNode = new ListNode(-1); dummyNode.next = head; ListNode pre = dummyNode; // 第 1 步:从虚拟头节点走 left - 1 步,来到 left 节点的前一个节点 // 建议写在 for 循环里,语义清晰 for (int i = 0; i < left - 1; i++) { pre = pre.next; } // 第 2 步:从 pre 再走 right - left + 1 步,来到 right 节点 ListNode rightNode = pre; for (int i = 0; i < right - left + 1; i++) { rightNode = rightNode.next; } // 第 3 步:切断出一个子链表(截取链表) ListNode leftNode = pre.next; ListNode curr = rightNode.next; // 注意:切断链接 pre.next = null; rightNode.next = null; // 第 4 步:同第 206 题,反转链表的子区间 reverseLinkedList(leftNode); // 第 5 步:接回到原来的链表中 pre.next = rightNode; leftNode.next = curr; return dummyNode.next; } private void reverseLinkedList(ListNode head) { // 也可以使用递归反转一个链表 ListNode pre = null; ListNode cur = head; while (cur != null) { ListNode next = cur.next; cur.next = pre; pre = cur; cur = next; } } } 作者:LeetCode-Solution 链接:https://leetcode-cn.com/problems/reverse-linked-list-ii/solution/fan-zhuan-lian-biao-ii-by-leetcode-solut-teyq/ 来源:力扣(LeetCode)
方法二:
使用链表的头插法。到需要反转的第一个位置时,将后面的节点改变到这个节点之前,完成反转。
class Solution { public ListNode reverseBetween(ListNode head, int left, int right) { // 设置 dummyNode 是这一类问题的一般做法 ListNode dummyNode = new ListNode(-1); dummyNode.next = head; ListNode pre = dummyNode; for (int i = 0; i < left - 1; i++) { pre = pre.next; } ListNode cur = pre.next; ListNode next; for (int i = 0; i < right - left; i++) { next = cur.next; cur.next = next.next; next.next = pre.next; pre.next = next; } return dummyNode.next; } } 作者:LeetCode-Solution 链接:https://leetcode-cn.com/problems/reverse-linked-list-ii/solution/fan-zhuan-lian-biao-ii-by-leetcode-solut-teyq/ 来源:力扣(LeetCode)