力扣 25. K 个一组翻转链表

题目

给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表。

k 是一个正整数,它的值小于或等于链表的长度。

如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序。

示例:

给你这个链表:1->2->3->4->5

当 k = 2 时,应当返回: 2->1->4->3->5

当 k = 3 时,应当返回: 3->2->1->4->5

说明:

你的算法只能使用常数的额外空间。
你不能只是单纯的改变节点内部的值,而是需要实际进行节点交换。

题解

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode reverseKGroup(ListNode head, int k) {
        ListNode tmp = new ListNode(0);
        tmp.next = head;
        ListNode pre = tmp;

        while(head != null){
            ListNode tail = pre;
            for(int i = 0; i < k; i++){  // 判断剩余长度是否足够
                tail = tail.next;
                if(tail == null)   // 后面不用翻转了
                    return tmp.next;
            }
            ListNode nex = tail.next;  // 标记后续链表

            pre.next = null;
            ListNode p = head;
            while(p != nex){  // 翻转
                ListNode q = p.next;  // q用来标记下一个节点
                p.next = pre.next;
                pre.next = p;
                p = q;
            }

            // 把子链表连回去, head翻转到了末尾
            head.next = nex;
            pre = head;
            head = head.next;   
        }
        return tmp.next;
    }
}

 

你可能感兴趣的:(力扣 25. K 个一组翻转链表)