LeetCodehot100-25 K 个一组翻转链表
class Solution { public: ListNode* reverseKGroup(ListNode* head, int k) { if (head nullptr || k 1) return head; ListNode dummy(0); dummy.next head; ListNode* prev dummy; // 指向待反转组的前一个节点 while (true) { // 检查剩余节点是否够k个 ListNode* tail prev; for (int i 0; i k; i) { tail tail-next; if (tail nullptr) return dummy.next; // 不足k个直接返回 } // 反转当前组的k个节点 ListNode* curr prev-next; ListNode* next curr-next; ListNode* groupTail curr; // 当前组的第一个节点会成为反转后的最后一个节点 for (int i 1; i k; i) { ListNode* temp next-next; next-next curr; curr next; next temp; } // 连接反转后的组 prev-next curr; groupTail-next next; // 移动prev到下一组的前一个节点 prev groupTail; } return dummy.next; } };class Solution { public: ListNode* reverseKGroup(ListNode* head, int k) { // 检查是否有k个节点 ListNode* curr head; int count 0; while (curr ! nullptr count k) { curr curr-next; count; } // 不足k个直接返回原链表 if (count k) return head; // 反转前k个节点 ListNode* prev nullptr; ListNode* next nullptr; curr head; for (int i 0; i k; i) { next curr-next; curr-next prev; prev curr; curr next; } // 递归反转剩余部分 head-next reverseKGroup(curr, k); return prev; } };
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2463598.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!