【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;
}
相关推荐
小欣加油5 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly6 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕7 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei7 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld8 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi89 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang10 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby11 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠11 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力12 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试