【算法】链表每k个节点反转 (js)

牛客链接:https://www.nowcoder.com/practice/b49c3dc907814e9bbfa8437c251b028e?tpId=196&&tqId=37080&rp=1&ru=/ta/job-code-total&qru=/ta/job-code-total/question-ranking

本人题解:

有点绕,好好理解

js 复制代码
/*
 * function ListNode(x){
 *   this.val = x;
 *   this.next = null;
 * }
 */
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param head ListNode类 
 * @param k int整型 
 * @return ListNode类
 */
// 解法,把当前子链表的头节点(反转后为尾节点),指向下一反转后的子链表的头节点
// 比如第一次翻转后 3->2->1->null  head是1->null,我们要把1指向下一翻转后子链表的头结点
function reverseKGroup( head ,  k ) {
    // write code here
    let tail = head;
    // 找到尾部用来作为下一子链表的头部
    for(let i=0;i<k;i++){
        // 不足k个则原样返回
        if(tail===null) return head;
        tail =  tail.next;
    }
    let pre = null;
    let cur = head;
    // 反转子链表
    for(let i=0;i<k;i++){
        const temp = cur.next;
        cur.next = pre;
        pre = cur;
        cur = temp;
    }
    // 利用递归不断反转链接链表,将反转后子链表的尾节点链接到下一翻转链表的头结点
    // 此处递归过程会开辟一个新的空间和变量
    head.next = reverseKGroup(tail,k);
    // 返回第一次反转子链表的头结点(整个链表的头结点)
    return pre;

}
module.exports = {
    reverseKGroup : reverseKGroup
};
相关推荐
默_笙4 小时前
🛬 我让 AI 帮我写了一个打飞机游戏,结果 Canvas 把我整不会了
前端·javascript
梯度不陡4 小时前
AI 到底能不能从零写软件?ProgramBench 和 RepoZero 给出了两种答案
前端·javascript·面试
胡萝卜术6 小时前
滑动窗口最大值:从暴力到单调队列,层层优化全解析
前端·javascript·面试
kyriewen7 小时前
2026 年了,这 6 个 npm 包可以卸载了——浏览器原生 API 已经能替代
前端·javascript·npm
铁皮饭盒8 小时前
bun直接tsx,优雅!
javascript·后端
_柳青杨10 小时前
一文吃透 Node.js 事件循环:从原理到 Node 20+ 重大变更
javascript·后端
JieE21220 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab1 天前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
一颗烂土豆1 天前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
kyriewen1 天前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程