【JavaScript】LeetCode:41-45

news/2024/9/22 13:38:20 标签: javascript, leetcode, 开发语言, 链表, 二叉树

文章目录

41 排序链表

在这里插入图片描述

  • 递归 + 归并排序
  • 找到链表中心点,从中心点将链表一分为二。奇数个节点找中心点,偶数个节点找中心左边的点作为中心点。
  • 快慢指针找中心点,当快指针移动到该段链表的最后一个元素时,慢指针所指向的节点为中心点。
  • 找到中心点后,中心点.next = null,将链表从中间断开。分别将前一半链表的头节点(head)和后一半链表的头节点(中心点.next)进行下一次划分。
  • 注意:快慢指针初始化时,快指针比慢指针快一步,方便链表只有2个节点时划分链表
  • 合并有序链表
    (1) 建立新节点作为新链表的哨兵节点。
    (2) left,right 分别指向两个链表的头部,比较两个指针处节点值的大小,从小到大插入到有序链表中,指针交替前进,直至其中一个链表为空。将剩余的链表直接插入到有序链表的尾部。
    (3) 返回哨兵节点.next。
javascript">/**
 * Definition for singly-linked list.
 * function ListNode(val, next) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 * }
 */
/**
 * @param {ListNode} head
 * @return {ListNode}
 */
var sortList = function(head) {
    if(head == null || head.next == null){ // 1个节点或0个节点
        return head;
    }
    let slow = head, fast = head.next;
    while(fast != null && fast.next != null){ // 奇数个节点fast = null停止,偶数个节点fast.next = null停止
        slow = slow.next;
        fast = fast.next.next;
    }
    let tmp = slow.next;
    slow.next = null;
    let left = sortList(head);
    let right = sortList(tmp);
    let dummy = new ListNode();
    let res = dummy;
    while(left != null && right != null){
        if(left.val < right.val){
            dummy.next = left;
            left = left.next;
        }else{
            dummy.next = right;
            right = right.next;
        }
        dummy = dummy.next;
    } 
    dummy.next = left? left: right;
    return res.next; 
};

42 合并k个升序链表

在这里插入图片描述

  • 方法1:最小堆。将头节点放入堆中,弹出最小值node,此时将node.next放入堆中,一直取到堆为空为止,每次取出最小值时,都将最小值的下一个节点放入堆中。
  • 方法2:分治。这里给出该方法的代码。
  • 链表数组lists一分为二,先合并前一半链表,再合并后一半链表,最后完成全部链表的合并。
  • 中心点为mid,前一半链表的区域为[左,mid],后一半链表的区域为[mid + 1,右]。
javascript">/**
 * Definition for singly-linked list.
 * function ListNode(val, next) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.next = (next===undefined ? null : next)
 * }
 */

var merge = function(left, right){
    let dummy = new ListNode();
    let cur = dummy;
    while(left != null && right != null){
        if(left.val < right.val){
            cur.next = left;
            left = left.next;
        }else{
            cur.next = right;
            right = right.next;
        }
        cur = cur.next;
    }
    cur.next = left? left: right;
    return dummy.next;
}

/**
 * @param {ListNode[]} lists
 * @return {ListNode}
 */
var mergeKLists = function(lists) {
    function partition(i, j){
        if(i == j){ // 区域内只有1个值
            return lists[i];
        }
        if(i > j){ // 非法区域
            return null;
        }
        let mid = Math.floor((i + j) / 2);
        let left = partition(i, mid);
        let right = partition(mid + 1, j);
        return merge(left, right);
    }
    return partition(0, lists.length - 1)
};

43 LRU缓存

在这里插入图片描述

  • 哈希表 + 双向链表
  • put:
    ① key不存在:创建新节点,添加进哈希表,添加到链表头部。如果当前容量 > capacity,删除链表尾部节点,删除哈希表中对应的项。
    ② key存在:通过哈希表找到key所在的节点,改变value,移动到链表头部。
  • get:
    ① key不存在:返回 -1。
    ② key存在:通过哈希表找到key所在的节点,移动到链表头部,返回value。
  • 这里给出的代码直接使用哈希表实现各类操作。
  • this.map.delete(key); this.map.set(key, value);:先删除,再将该节点添加到最后。
  • this.map.keys().next().value;:哈希表中第一个键值。
javascript">/**
 * @param {number} capacity
 */
var LRUCache = function(capacity) {
    this.capacity = capacity;
    this.map = new Map();
};

/** 
 * @param {number} key
 * @return {number}
 */
LRUCache.prototype.get = function(key) {
    if(this.map.has(key)){
        let value = this.map.get(key);
        this.map.delete(key);
        this.map.set(key, value);
        return value;
    }else{
        return -1;
    }
};

/** 
 * @param {number} key 
 * @param {number} value
 * @return {void}
 */
LRUCache.prototype.put = function(key, value) {
    if(this.map.has(key)){
        let value = this.map.get(key);
        this.map.delete(key);
    }
    this.map.set(key, value);
    if(this.map.size > this.capacity){
        this.map.delete(this.map.keys().next().value);
    }
};

/**
 * Your LRUCache object will be instantiated and called as such:
 * var obj = new LRUCache(capacity)
 * var param_1 = obj.get(key)
 * obj.put(key,value)
 */

44 二叉树的中序遍历

在这里插入图片描述

  • 方法1:递归法。
javascript">/**
 * Definition for a binary tree node.
 * function TreeNode(val, left, right) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.left = (left===undefined ? null : left)
 *     this.right = (right===undefined ? null : right)
 * }
 */
/**
 * @param {TreeNode} root
 * @return {number[]}
 */
var inorderTraversal = function(root) {
    var res = [];
    var traversal = function(root){
        if(root == null){
            return;
        }
        traversal(root.left);  // 左
        res.push(root.val);    // 根
        traversal(root.right); // 右
    }
    traversal(root);
    return res;
};
  • 方法2:迭代法。
  • 遍历顺序与处理顺序不同。
javascript">/**
 * Definition for a binary tree node.
 * function TreeNode(val, left, right) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.left = (left===undefined ? null : left)
 *     this.right = (right===undefined ? null : right)
 * }
 */
/**
 * @param {TreeNode} root
 * @return {number[]}
 */
var inorderTraversal = function(root) {
    var res = []; // 存放结果
    var vis = []; // 模拟遍历队列,存放访问过的元素
    while(root != null || vis.length != 0){
        if(root != null){
            vis.push(root);
            root = root.left;   // 左
        }else{
            root = vis.pop();
            res.push(root.val); // 根
            root = root.right;  // 右
        }
    }
    return res;
};

45 二叉树的最大深度

在这里插入图片描述

  • 深度:任意节点到根节点的距离,使用前序遍历。
  • 高度:任意节点到叶子节点的距离,使用后序遍历。
  • 根节点的高度就是二叉树的最大深度。
  • 这里使用后序遍历,即通过求根节点高度得出二叉树的最大深度。
javascript">/**
 * Definition for a binary tree node.
 * function TreeNode(val, left, right) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.left = (left===undefined ? null : left)
 *     this.right = (right===undefined ? null : right)
 * }
 */
/**
 * @param {TreeNode} root
 * @return {number}
 */
var maxDepth = function(root) {
    if(root == null){
        return 0;
    }
    var leftheight = maxDepth(root.left);
    var rightheight = maxDepth(root.right);
    var height = Math.max(leftheight, rightheight) + 1;
    return height;
};

http://www.niftyadmin.cn/n/5670356.html

相关文章

树及二叉树(选择题)

树 在树中&#xff0c;总结点数为所有结点的度和再加一 5、设一棵度为3的树&#xff0c;其中度为2&#xff0c;1.0的结点数分别为3&#xff0c;1&#xff0c;6。该树中度为3 的结点数为_。 二叉树 设二叉树的所有节点个数为N&#xff0c;度为零的结点&#xff08;叶子结点…

python调用c++动态链接库,环境是VS2022和vscode2023

目录 前言&#xff1a;配置环境&#xff1a;基础夯实&#xff08;对于ctypes的介绍&#xff09;&#xff1a;1. 加载共享库2. 定义函数原型3. 调用函数4. 处理数据结构5. 处理指针6. 错误处理7. 使用 ctypes.util总结 效果展示&#xff1a;操作步骤(保姆级教学)一在VS中创建dll…

【Prometheus】jmx_prometheus_javaagent监控java应用

目录 一、概述 1.1 promethues简介 1.2 JMX Exporter简介 二、监控SparkHistoryServer实现 一、概述 1.1 promethues简介 promethues采集数据的方法很多&#xff0c;常用的是通过各种exporter去主机采集&#xff0c;然后有些程序是没有相关的exporter,所以有些时候会通过脚…

MATLAB入门基础篇

1. 数值计算和符号计算功能 在MATLAB环境中,有超过500种数学、统计、科学及工程方面的函数可使用,函数的标示自然,使得问题和解答像数学式子一般简单明了,让使用者可全力发挥在解题方面,而非浪费在电脑操作上. 2.图形功能 利用MATLAB的高级图形命令可以轻而易举地绘…

CleanClip --- 为Mac用户打造的智能剪贴板管理利器

CleanClip是一款专为Mac用户设计的强大剪贴板管理工具&#xff0c;旨在提升用户的工作效率和数据管理体验。它通过智能化的剪贴板内容管理&#xff0c;实现了Mac系统与用户操作之间的无缝衔接。CleanClip支持多种连接方式&#xff0c;包括系统级的快捷操作和自定义快捷键&#…

基于Windows系统以tomcat为案例,讲解如何新增自启动服务,定时重启服务。

文章目录 引言I 设置服务自启动的常规操作II 安装多个tomcat服务,并设置自启动。III 定时重启服务引言 为了同一个版本安装多个tomcat服务,并设置自启动。使用Windows的任务计划程序来创建一个定时任务,用于重启Tomcat服务。I 设置服务自启动的常规操作 运行窗口输入control…

美国火箭实验室Rocket Lab USA(RKLB)

火箭实验室&#xff08;Rocket Lab&#xff09;是一家美国私营航空航天制造商和小型卫星发射服务提供商&#xff0c;由新西兰工程师彼得贝克在2006年创立&#xff0c;并于2013年在美国加州设立了总部&#xff0c;在新西兰拥有全资子公司。该公司开发小型火箭&#xff0c;并进行…

网络安全-webshell绕过,hash碰撞,webshell绕过原理

目录 一、题目 1.1 1.2 1.3 1.4 1.5 二、绕过动态检测引擎的一次尝试 三、一个比赛中的webshell 四、webshell绕过的原理以及哈希碰撞 五、JSP解释流程导致的绕过&#xff08;QT比赛&#xff09; 5.1环境 5.2例子 一、题目 这里我们通过几道题目来给大家讲解 1.…