【算法】链表每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
};
相关推荐
武子康几秒前
AI研究-133 Java vs Kotlin/Go/Rust/Python/Node:2025 详细对比分析 定位与取舍指南
java·javascript·python·golang·rust·kotlin·node
小帆聊前端3 分钟前
深度解读虚拟列表:从原理到实战,解决长列表渲染性能难题
前端·javascript
吃着火锅x唱着歌5 分钟前
LeetCode 2364.统计坏数对的数目
数据结构·算法·leetcode
qq_336313939 分钟前
java基础-set类集合进阶
java·算法
狮子座的男孩18 分钟前
js函数高级:03、详解原型与原型链(原型、显式原型与隐式原型、原型链、原型链属性、探索instanceof、案例图解)及相关面试题
前端·javascript·经验分享·显示原型与隐式原型·原型链及属性·探索instanceof·原型与原型链图解
嵌入式老牛19 分钟前
第13章 图像处理之Harris角点检测算法(二)
图像处理·opencv·算法·计算机视觉
渡我白衣20 分钟前
哈希的暴力美学——std::unordered_map 的底层风暴、扩容黑盒与哈希冲突终极博弈
java·c语言·c++·人工智能·深度学习·算法·哈希算法
zl_vslam23 分钟前
SLAM中的非线性优-3D图优化之相对位姿Between Factor(六)
前端·人工智能·算法·计算机视觉·slam se2 非线性优化
budingxiaomoli37 分钟前
算法--位运算
算法
熊猫_豆豆42 分钟前
基于A*算法的雷雨绕飞路径MATLAB实现
算法·matlab·航天·a星算法