【LeetCode热题100(31/100)】K 个一组翻转链表

题目地址: 链接
思路:

从头节点开始,判读之后的节点长度是否超过k

  • 若超过,则反转之后的 k 节点,使用头插法进行翻转
  • 没有超过,结束循环。

最后返回头节点即可。

js 复制代码
/**
 * Definition for singly-linked list.
 * function ListNode(val, next) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 * }
 */
/**
 * @param {ListNode} head
 * @param {number} k
 * @return {ListNode}
 */
var reverseKGroup = function(head, k) {
    const dummy = new ListNode(0, head);
    let [p, q] = [dummy, dummy];
    while(p) {
        let l = k;
        while(l -- && p) {
            p = p.next;
        }
        if(p) p = kRev(q, k);
        q = p;
    }
    return dummy.next;
};


/**
 * 反转从 dummy 后 k 个节点
 */
var kRev = function(dummy, k) {
    let head = dummy.next;

    dummy.next = null;
    let p = head;
    for(let i = 0; i < k; i ++) {
        let q = p;
        p = p.next;
        q.next = dummy.next;
        dummy.next = q;
    }
    let np = dummy;
    while(np.next) np = np.next;
    np.next = p; 
    return np;
}
相关推荐
Blossom.118几秒前
从“金鱼记忆“到“超级大脑“:2025年AI智能体记忆机制与MoE架构的融合革命
人工智能·python·算法·架构·自动化·whisper·哈希算法
金枪不摆鳍1 分钟前
算法-贪心算法
算法·贪心算法
naruto_lnq1 分钟前
高性能消息队列实现
开发语言·c++·算法
池央3 分钟前
贪心算法-摆动序列
算法·贪心算法
AndrewHZ4 分钟前
【AI黑话日日新】什么是隐式CoT?
人工智能·深度学习·算法·llm·cot·复杂推理
芒克芒克6 分钟前
LeetCode 跳跃游戏 II 最优解法:贪心算法
leetcode·游戏·贪心算法
User_芊芊君子8 分钟前
【LeetCode原地复写零】:双指针+逆向填充,O(n)时间O(1)空间最优解!
android·linux·leetcode
格林威8 分钟前
Baumer相机视野内微小缺陷增强检测:提升亚像素级瑕疵可见性的 7 个核心方法,附 OpenCV+Halcon 实战代码!
人工智能·数码相机·opencv·算法·计算机视觉·视觉检测·工业相机
进击的荆棘1 小时前
优选算法——滑动窗口
c++·算法·leetcode
csdn_aspnet1 小时前
奈飞工厂算法:个性化推荐系统的极限复刻
算法·netflix·奈飞