class Solution {

    /**
     * 逆转链表,返回头尾
     * @param head
     * @return
     */
    private static ListNode[] reverse(ListNode head, ListNode end) {
        if (head == null) {
            return new ListNode[2];
        }
        ListNode[] result = new ListNode[2];
        result[1] = head;

        ListNode pre = null;
        ListNode next;
        ListNode tail = end.next;
        while (head != tail) {
            next = head.next;
            head.next = pre;
            pre = head;
            head = next;
        }

        result[0] = pre;

        return result;
    }

    private static ListNode function(ListNode head, int k) {
        if (k < 2) {
            return head;
        }

        ListNode pre = null;
        ListNode result = null;
        ListNode start = head;
        int index = 1;
        while (head != null) {
            ListNode next = head.next;
            if (index % k == 0) {
                ListNode[] reverse = reverse(start, head);
                // result == null,则此时为第一段
                if (result == null) {
                    result = reverse[0];
                } else {
                    pre.next = reverse[0];
                }
                pre = reverse[1];
                pre.next = next;
                start = next;
            }
            ++ index;
            head = next;
        }

        return result;
    }

    private static void print(ListNode head) {
        while (head != null) {
            System.out.println(head.val);
            head = head.next;
        }
    }

    public static void main(String[] args) {
        ListNode n1 = new ListNode(1);
        ListNode n2 = new ListNode(2);
        ListNode n3 = new ListNode(3);
        ListNode n4 = new ListNode(4);
        ListNode n5 = new ListNode(5);
        ListNode n6 = new ListNode(6);
        ListNode n7 = new ListNode(7);
        ListNode n8 = new ListNode(8);
        n1.next = n2;
        n2.next = n3;
        n3.next = n4;
        n4.next = n5;
        n5.next = n6;
        n6.next = n7;
        n7.next = n8;

        ListNode head = function(n1, 8);


        print(head);

    }
}

class ListNode {
    int val;
    ListNode next;
    ListNode(int x) { val = x; }
}