LeetCode 25. Reverse Nodes in k-Group

    xiaoxiao2025-08-02  17

    LeetCode 25. Reverse Nodes in k-Group

    DescriptionExampleNoteCodeConclusion

    Description

    Given a linked list, reverse the nodes of a linked list k at a time and return its modified list. k is a positive integer and is less than or equal to the length of the linked list. If the number of nodes is not a multiple of k then left-out nodes in the end should remain as it is.

    Example

    Given this linked list: 1->2->3->4->5 For k = 2, you should return: 2->1->4->3->5 For k = 3, you should return: 3->2->1->4->5

    Note

    Only constant extra memory is allowed.You may not alter the values in the list’s nodes, only nodes itself may be changed.

    Code

    java /** * 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) { LinkedList<ListNode> list = new LinkedList<ListNode>(); ListNode nHead = null, pNode = head, cur, pre = null; int count = 0; while(pNode != null) { count++; list.add(pNode); pNode = pNode.next; if(count % k == 0) { do { cur = list.removeLast(); if(nHead == null) { nHead = pre = cur; } else { pre.next = cur; pre = cur; } } while(!list.isEmpty()); } } if(list.isEmpty() && pre != null) { pre.next = null; } else { while(!list.isEmpty()) { cur = list.pop(); if(nHead == null) { nHead = pre = cur; } else { pre.next = cur; pre = cur; } } } return nHead; } } Others’ Solutionjava public ListNode reverseKGroup(ListNode head, int k) { ListNode curr = head; int count = 0; while (curr != null && count != k) { // find the k+1 node curr = curr.next; count++; } if (count == k) { // if k+1 node is found curr = reverseKGroup(curr, k); // reverse list with k+1 node as head // head - head-pointer to direct part, // curr - head-pointer to reversed part; while (count-- > 0) { // reverse current k-group: ListNode tmp = head.next; // tmp - next head in direct part head.next = curr; // preappending "direct" head to the reversed list curr = head; // move head of reversed part to a new node head = tmp; // move "direct" head to the next node in direct part } head = curr; } return head; }

    Conclusion

    给评论区的递归版本跪了
    最新回复(0)