当前位置: 首页 > article >正文

Hot100-链表-JS

160.相交链表

160. 相交链表
已解答
简单
相关标签
相关企业

给你两个单链表的头节点 headAheadB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null

图示两个链表在节点 c1 开始相交

题目数据 保证 整个链式结构中不存在环。

注意,函数返回结果后,链表必须 保持其原始结构

自定义评测:

评测系统 的输入如下(你设计的程序 不适用 此输入):

  • intersectVal - 相交的起始节点的值。如果不存在相交节点,这一值为 0
  • listA - 第一个链表
  • listB - 第二个链表
  • skipA - 在 listA 中(从头节点开始)跳到交叉节点的节点数
  • skipB - 在 listB 中(从头节点开始)跳到交叉节点的节点数

评测系统将根据这些输入创建链式数据结构,并将两个头节点 headAheadB 传递给你的程序。如果程序能够正确返回相交节点,那么你的解决方案将被 视作正确答案

示例 1:

输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,6,1,8,4,5], skipA = 2, skipB = 3
输出:Intersected at '8'
解释:相交节点的值为 8 (注意,如果两个链表相交则不能为 0)。
从各自的表头开始算起,链表 A 为 [4,1,8,4,5],链表 B 为 [5,6,1,8,4,5]。
在 A 中,相交节点前有 2 个节点;在 B 中,相交节点前有 3 个节点。
— 请注意相交节点的值不为 1,因为在链表 A 和链表 B 之中值为 1 的节点 (A 中第二个节点和 B 中第三个节点) 是不同的节点。换句话说,它们在内存中指向两个不同的位置,而链表 A 和链表 B 中值为 8 的节点 (A 中第三个节点,B 中第四个节点) 在内存中指向相同的位置。

示例 2:

输入:intersectVal = 2, listA = [1,9,1,2,4], listB = [3,2,4], skipA = 3, skipB = 1
输出:Intersected at '2'
解释:相交节点的值为 2 (注意,如果两个链表相交则不能为 0)。
从各自的表头开始算起,链表 A 为 [1,9,1,2,4],链表 B 为 [3,2,4]。
在 A 中,相交节点前有 3 个节点;在 B 中,相交节点前有 1 个节点。

示例 3:

输入:intersectVal = 0, listA = [2,6,4], listB = [1,5], skipA = 3, skipB = 2
输出:No intersection
解释:从各自的表头开始算起,链表 A 为 [2,6,4],链表 B 为 [1,5]。
由于这两个链表不相交,所以 intersectVal 必须为 0,而 skipA 和 skipB 可以是任意值。
这两个链表不相交,因此返回 null 。

提示:

  • listA 中节点数目为 m
  • listB 中节点数目为 n
  • 1 <= m, n <= 3 * 104
  • 1 <= Node.val <= 105
  • 0 <= skipA <= m
  • 0 <= skipB <= n
  • 如果 listAlistB 没有交点,intersectVal0
  • 如果 listAlistB 有交点,intersectVal == listA[skipA] == listB[skipB]

进阶:你能否设计一个时间复杂度 O(m + n) 、仅用 O(1) 内存的解决方案?

实现思路

  1. 变量作用域优化​:

    • 在 if (lengthA > lengthB) 和 else 分支中,分别处理 l1 或 l2 的移动,避免混淆。
    • 在 while (l1 && l2) 循环中,统一检查 l1 === l2,逻辑更清晰。
  2. 合并逻辑分支​:

    • 将两个 if 分支的逻辑合并为一个通用的 while (l1 && l2) 循环,减少重复代码。
  3. 指针移动时机​:

    • 在计算长度后,先让较长的链表移动 diff 步,然后同时遍历两个链表,直到找到交点或遍历结束。
  4. 返回值修正​:

    • 无论哪个链表先走到交点,都返回 l1 或 l2(因为此时 l1 === l2)。

代码实现

var getIntersectionNode = function(headA, headB) {let l1 = headA;let l2 = headB;let lengthA = 0, lengthB = 0;// 计算链表 A 的长度while (l1) {l1 = l1.next;lengthA++;}// 计算链表 B 的长度while (l2) {l2 = l2.next;lengthB++;}// 重置指针l1 = headA;l2 = headB;// 让较长的链表先走差值步let diff = Math.abs(lengthA - lengthB);if (lengthA > lengthB) {while (diff--) {l1 = l1.next;}} else {while (diff--) {l2 = l2.next;}}// 同时遍历,寻找交点while (l1 && l2) {if (l1 === l2) {return l1; // 返回交点}l1 = l1.next;l2 = l2.next;}return null; // 无交点
};

 206.反转链表

206. 反转链表

 

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例 1:

输入:head = [1,2,3,4,5]
输出:[5,4,3,2,1]

示例 2:

输入:head = [1,2]
输出:[2,1]

示例 3:

输入:head = []
输出:[]

提示:

  • 链表中节点的数目范围是 [0, 5000]
  • -5000 <= Node.val <= 5000

进阶:链表可以选用迭代或递归方式完成反转。你能否用两种方法解决这道题?

var reverseList = function(head) {let prev = null; // 前驱节点let current = head; // 当前节点let temp; // 暂存当前节点的下一个节点while (current) {temp = current.next; // 暂存下一个节点current.next = prev; // 反转当前节点的指针prev = current; // 移动 prev 到当前节点current = temp; // 移动 current 到下一个节点}return prev; // 返回新的头节点
};

 234.回文链表

234. 回文链表

已解答

简单

相关标签

相关企业

给你一个单链表的头节点 head ,请你判断该链表是否为

。如果是,返回 true ;否则,返回 false

示例 1:

输入:head = [1,2,2,1]
输出:true

示例 2:

输入:head = [1,2]
输出:false

提示:

  • 链表中节点数目在范围[1, 105]
  • 0 <= Node.val <= 9

进阶:你能否用 O(n) 时间复杂度和 O(1) 空间复杂度解决此题?

/*** 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 {boolean}*/
var isPalindrome = function(head) {// 获得长度,然后用栈的操作 前一半入栈 后一半出栈let stack1=[];let length=0let p=head;while(p){length++;p=p.next;}p=head;// 存储前一半的数for(let i=0;i<Math.floor(length/2);i++){stack1.push(p.val);p=p.next;}// 如果为奇数就跳过中间的数if(length%2===1){p=p.next; }// 现在p指针位于后一段的第一个数上// 比较后一段的数和前一段是否相等for(let i=0;i<Math.floor(length/2);i++){if(p.val===stack1.pop()){p=p.next;}else{return false;}}return true;
};

141.环形链表I

141. 环形链表

已解答

简单

相关标签

相关企业

给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。

如果链表中存在环 ,则返回 true 。 否则,返回 false

示例 1:

输入:head = [3,2,0,-4], pos = 1
输出:true
解释:链表中有一个环,其尾部连接到第二个节点。

示例 2:

输入:head = [1,2], pos = 0
输出:true
解释:链表中有一个环,其尾部连接到第一个节点。

示例 3:

输入:head = [1], pos = -1
输出:false
解释:链表中没有环。

提示:

  • 链表中节点的数目范围是 [0, 104]
  • -105 <= Node.val <= 105
  • pos-1 或者链表中的一个 有效索引

进阶:你能用 O(1)(即,常量)内存解决此问题吗?

/*** Definition for singly-linked list.* function ListNode(val) {*     this.val = val;*     this.next = null;* }*//*** @param {ListNode} head* @return {boolean}*/
var hasCycle = function(head) {let slow=head;let fast=head;while (fast && fast.next) {slow = slow.next;          // 慢指针走 1 步fast = fast.next.next;     // 快指针走 2 步if (slow === fast) return true; // 快慢指针相遇,有环}return false; // 快指针到达末尾,无环
};

142.环形链表II

142. 环形链表 II

已解答

中等

相关标签

相关企业

给定一个链表的头节点  head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos-1,则在该链表中没有环。注意:pos 不作为参数进行传递,仅仅是为了标识链表的实际情况。

不允许修改 链表。

    示例 1:

    输入:head = [3,2,0,-4], pos = 1
    输出:返回索引为 1 的链表节点
    解释:链表中有一个环,其尾部连接到第二个节点。
    

    示例 2:

    输入:head = [1,2], pos = 0
    输出:返回索引为 0 的链表节点
    解释:链表中有一个环,其尾部连接到第一个节点。
    

    示例 3:

    输入:head = [1], pos = -1
    输出:返回 null
    解释:链表中没有环。
    

    提示:

    • 链表中节点的数目范围在范围 [0, 104]
    • -105 <= Node.val <= 105
    • pos 的值为 -1 或者链表中的一个有效索引

    进阶:你是否可以使用 O(1) 空间解决此题?

    实现思路

    1. 检测环​:

      • 使用快慢指针(slow 和 fast),如果它们相遇,说明有环。
    2. 找到环的起始节点​:

      • 相遇后,重新设置 ptr1 指向链表头部,ptr2 指向相遇点。
      • 然后 ptr1 和 ptr2 以相同速度移动,它们的交点就是环的起始节点。
    3. ​**无环时返回 null**​:

      • 如果 fast 或 fast.next 为 null,说明链表无环,返回 null

    为什么这样能找到环的起始节点?​

    • 设链表头到环起点的距离为 a,环起点到相遇点的距离为 b,相遇点到环起点的距离为 c
    • 快指针走的距离是慢指针的 2 倍:2(a+b)=a+b+k⋅(b+c)其中 k 是快指针在环内绕的圈数。
    • 化简得:a+b=k⋅(b+c)a=(k−1)⋅(b+c)+c这意味着从链表头到环起点的距离 a 等于从相遇点再走 c 步的距离。
    • 因此,当 ptr1(从头开始)和 ptr2(从相遇点开始)以相同速度移动时,它们会在环起点相遇。

    代码实现

    /*** Definition for singly-linked list.* function ListNode(val) {*     this.val = val;*     this.next = null;* }*//*** @param {ListNode} head* @return {ListNode}*/
    var detectCycle = function (head) {let slow = head;let fast = head;while (fast && fast.next) {slow = slow.next;          // 慢指针走 1 步fast = fast.next.next;     // 快指针走 2 步if (slow === fast) {// 找到环后,重新定位指针找环的起始节点let ptr1 = head;let ptr2 = slow;while (ptr1 !== ptr2) {ptr1 = ptr1.next;ptr2 = ptr2.next;}return ptr1; // 返回环的起始节点}}return null; // 快指针到达末尾,无环
    };
    

    21.合并两个有序链表

    21. 合并两个有序链表

    已解答

    简单

    相关标签

    相关企业

    将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 

    示例 1:

    输入:l1 = [1,2,4], l2 = [1,3,4]
    输出:[1,1,2,3,4,4]
    

    示例 2:

    输入:l1 = [], l2 = []
    输出:[]
    

    示例 3:

    输入:l1 = [], l2 = [0]
    输出:[0]
    

    提示:

    • 两个链表的节点数目范围是 [0, 50]
    • -100 <= Node.val <= 100
    • l1l2 均按 非递减顺序 排列
    1. 使用哑节点(Dummy Node)​​:

      • 哑节点是一个虚拟节点,用于简化链表操作。它作为合并后链表的起始点,避免处理头节点的特殊情况。
    2. 正确合并逻辑​:

      • 比较 l1 和 l2 的当前节点值,将较小的节点连接到 current.next
      • 移动较小节点的指针(l1 或 l2)到下一个节点。
      • 移动 current 到新连接的节点。
    3. 处理剩余节点​:

      • 当其中一个链表遍历完后,直接将另一个链表的剩余部分连接到 current.next
    4. 返回合并后的链表头节点​:

      • 返回 dummy.next,即合并后链表的真正头节点。

    /*** Definition for singly-linked list.* function ListNode(val, next) {*     this.val = (val===undefined ? 0 : val)*     this.next = (next===undefined ? null : next)* }*/
    /*** @param {ListNode} list1* @param {ListNode} list2* @return {ListNode}*/
    function mergeTwoLists(l1, l2) {// 创建一个哑节点(dummy node)作为合并后链表的起始点let dummy = new ListNode(-1);let current = dummy;while(l1&&l2){if(l1.val<=l2.val){current.next=l1l1=l1.next}else{current.next = l2;l2 = l2.next;}current=current.next}// 将剩余的链表直接连接到合并后的链表if (l1 !== null) {current.next = l1;} else {current.next = l2;}// 返回合并后的链表头节点(跳过哑节点)return dummy.next;
    }

     2.两数相加

    2. 两数相加

     

    给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。

    请你将两个数相加,并以相同形式返回一个表示和的链表。

    你可以假设除了数字 0 之外,这两个数都不会以 0 开头。

    示例 1:

    输入:l1 = [2,4,3], l2 = [5,6,4]
    输出:[7,0,8]
    解释:342 + 465 = 807.
    

    示例 2:

    输入:l1 = [0], l2 = [0]
    输出:[0]
    

    示例 3:

    输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
    输出:[8,9,9,9,0,0,0,1]
    

    提示:

    • 每个链表中的节点数在范围 [1, 100]
    • 0 <= Node.val <= 9
    • 题目数据保证列表表示的数字不含前导零
    /*** Definition for singly-linked list.* function ListNode(val, next) {*     this.val = (val===undefined ? 0 : val)*     this.next = (next===undefined ? null : next)* }*/
    /*** @param {ListNode} l1* @param {ListNode} l2* @return {ListNode}*/
    var addTwoNumbers = function (l1, l2) {let dummy = new ListNode(-1); // 哑节点let current = dummy;let carry = 0; // 进位while (l1 !== null || l2 !== null || carry !== 0) {// 获取当前节点的值(如果节点存在)let val1 = l1 ? l1.val : 0;let val2 = l2 ? l2.val : 0;// 计算当前位的和 + 进位let sum = val1 + val2 + carry;carry = Math.floor(sum / 10); // 计算新的进位current.next = new ListNode(sum % 10); // 创建新节点current = current.next; // 移动 current 指针// 移动 l1 和 l2 指针if (l1) l1 = l1.next;if (l2) l2 = l2.next;}return dummy.next; // 返回合并后的链表头节点
    };

    19.删除链表的倒数第n个节点

    19. 删除链表的倒数第 N 个结点

    已解答

    中等

    相关标签

    相关企业

    提示

    给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

    示例 1:

    输入:head = [1,2,3,4,5], n = 2
    输出:[1,2,3,5]
    

    示例 2:

    输入:head = [1], n = 1
    输出:[]
    

    示例 3:

    输入:head = [1,2], n = 1
    输出:[1]
    

    提示:

    • 链表中结点的数目为 sz
    • 1 <= sz <= 30
    • 0 <= Node.val <= 100
    • 1 <= n <= sz

    /*** 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} n* @return {ListNode}*/
    var removeNthFromEnd = function (head, n) {// length为链表长度let length = 0;// p指向头节点let p = head// 计算链表长度while (p) {length++p = p.next}// 如果要删除的是头节点if (n === length) {return head.next;}// 找到倒数第 n+1 个节点p = headfor (let i = 1; i < length - n; i++) {p = p.next}// 删除倒数第 n 个节点p.next = p.next.next;return head
    };

    24.两两交换链表中的节点

    24. 两两交换链表中的节点

     

    给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。

    示例 1:

    输入:head = [1,2,3,4]
    输出:[2,1,4,3]
    

    示例 2:

    输入:head = []
    输出:[]
    

    示例 3:

    输入:head = [1]
    输出:[1]
    

    提示:

    • 链表中节点的数目在范围 [0, 100]
    • 0 <= Node.val <= 100
    /*** 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 swapPairs = function (head) {// 创建哑节点,简化头节点交换let dummy = new ListNode(0)dummy.next = headlet prev = dummywhile (prev.next && prev.next.next) {// 当前要交换的两个节点let first = prev.nextlet second = prev.next.next// 执行交换prev.next = second// 哑节点指向第二个节点first.next = second.next// 第一个节点指向第二个节点的下一个second.next = first  // 第二个节点指向第一个节点// 移动prev指针到下一对的前驱prev = first}return dummy.next
    };

     

    相关文章:

    Hot100-链表-JS

    160.相交链表 160. 相交链表 已解答 简单 相关标签 相关企业 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点&#xff0c;返回 null 。 图示两个链表在节点 c1 开始相交&#xff1a; 题目数据 保证 整…...

    事件驱动架构:从传统服务到实时响应的IT新风潮

    文章目录 事件驱动架构的本质&#xff1a;从请求到事件的范式转变在EDA中&#xff1a; 事件驱动架构的演进&#xff1a;从消息队列到云原生标配核心技术&#xff1a;事件驱动架构的基石与工具链1. 消息队列&#xff1a;事件传递的枢纽2. 消费者&#xff1a;异步处理3. 事件总线…...

    网络流量分析 | NetworkMiner

    介绍 NetworkMiner 是一款适用于Windows&#xff08;也适用于Linux/Mac&#xff09;的开源网络取证分析工具。它可被用作被动网络嗅探器/数据包捕获工具&#xff0c;也可被用于检测操作系统、会话、主机名、开放端口等&#xff0c;还能被用于解析pcap文件进行离线分析。点击此…...

    弦理论的额外维度指的是什么,宇宙中有何依据

    弦理论中的额外维度是解释微观世界与宏观宇宙矛盾的关键假设之一。它们并非科幻中的平行宇宙&#xff0c;而是通过严谨的数学框架提出&#xff0c;并可能留下可观测的宇宙学痕迹。以下是具体解析&#xff1a; 一、弦理论为何需要额外维度&#xff1f; 数学自洽性要求 弦理论中…...

    std::tuple 用法

    std::tuple 是 C11 引入的模板类&#xff0c;用来存储多个不同类型的值&#xff0c;类似于 Python 的元组。你可以把它看作是一种“组合多个变量在一个对象中”的方式。 ✅ 基本用法 #include <tuple> #include <iostream>int main() {std::tuple<int, std::st…...

    深入理解 Git 分支操作的底层原理

    在软件开发的世界里&#xff0c;Git 已经成为了版本控制的标配工具。而 Git 分支功能&#xff0c;更是极大地提升了团队协作和项目开发的效率。我们在日常开发中频繁地创建、切换和合并分支&#xff0c;但是这些操作背后的底层原理是怎样的呢&#xff1f;在之前的博客探秘Git底…...

    Excel MCP: 自动读取、提炼、分析Excel数据并生成可视化图表和分析报告

    最近&#xff0c;一款Excel MCP Server的开源工具火了&#xff0c;看起来功能很强大&#xff0c;咱们今天来一探究竟。 基础环境 最近两年&#xff0c;大家都可以看到AI的发展有多快&#xff0c;我国超10亿参数的大模型&#xff0c;在短短一年之内&#xff0c;已经超过了100个&…...

    C语言:深入理解指针(4)

    目录 一、字符指针变量 二、数组指针变量 三、二维数组传参的本质 四、函数指针变量 五、typedef 类型重命名 六、函数指针数组 一、字符指针变量 我们常见的字符指针变量是这样的&#xff1a; char a w; char* p &a; char arr[] "abcd"; char* pa ar…...

    Gensim 是一个专为 Python 设计的开源库

    Gensim 是一个专为 Python 设计的开源库&#xff0c;其核心代码和生态系统均基于 Python 构建&#xff0c;目前官方仅支持 Python 语言。如果你需要在其他编程语言中实现类似功能&#xff08;如词向量训练、主题模型等&#xff09;&#xff0c;通常需要使用对应语言的替代库或通…...

    质量管理工程师面试总结

    今天闲着无聊参加了学校招聘会的一家双选会企业&#xff0c;以下是面试的过程。 此次面试采用的是一对多的形式。&#xff08;此次三个求职者&#xff0c;一个面试官&#xff09; 面试官&#xff1a;开始你们每个人先做个自我介绍吧。 哈哈哈哈哈哈哈哈&#xff0c;其实我们…...

    python 爬虫框架介绍

    文章目录 前言一、Requests BeautifulSoup&#xff08;基础组合&#xff09;二、Scrapy&#xff08;高级框架&#xff09;三、PySpider&#xff08;可视化爬虫&#xff09;四、Selenium&#xff08;浏览器自动化&#xff09;五、Playwright&#xff08;新一代浏览器自动化&…...

    window 显示驱动开发-使用有保证的协定 DMA 缓冲区模型

    Windows Vista 的显示驱动程序模型保证呈现设备的 DMA 缓冲区和修补程序位置列表的大小。 修补程序位置列表包含 DMA 缓冲区中命令引用的资源的物理内存地址。 在有保证的协定模式下&#xff0c;用户模式显示驱动程序知道 DMA 缓冲区和修补程序位置列表的确切大小&#xff0c;…...

    蓝牙协议架构与调试工具详解(含 BLE、HCI 命令、调试命令)

    本文介绍蓝牙协议从物理层到应用层的完整通信流程&#xff0c;并详解了 Linux 下主流蓝牙调试工具的使用方法&#xff0c;适用于嵌入式蓝牙驱动开发、BLE调试、通信协议分析等场景。 &#x1f527; 1. 蓝牙架构概览 ✅ 芯片架构 单模芯片&#xff1a;仅支持 BLE 或 Classic 蓝…...

    预测模型开发与评估:基于机器学习的数据分析实践

    在当今数据驱动的时代&#xff0c;预测模型已成为各行各业决策制定的核心工具。本文将分享我在COMP5310课程项目中开发预测模型的经验&#xff0c;探讨从数据清洗到模型优化的完整过程&#xff0c;并提供详细的技术实现代码。 ## 研究问题与数据集 ### 研究问题 我们的研究聚焦…...

    提高表达能力

    你遇到的这种情况其实很常见&#xff0c;背后的原因可能涉及思维模式、心理状态和表达习惯的综合作用。以下是具体分析和解决方案&#xff1a; 1. 原因分析&#xff1a;为什么讨论时流畅&#xff0c;独自表达却卡壳&#xff1f; 外部反馈缺失&#xff1a;讨论时对方的提问、反…...

    【更新】全国省市县-公开手机基站数据集(2006-2025.3)

    手机基站是现代通信网络中的重要组成部分&#xff0c;它们为广泛的通信服务提供基础设施。随着数字化进程的不断推进&#xff0c;手机基站的建设与布局对优化网络质量和提升通信服务水平起着至关重要的作用&#xff0c;本分享数据可帮助分析移动通信网络的发展和优化。本次数据…...

    基于MNIST数据集的手写数字识别(CNN)

    目录 一&#xff0c;模型训练 1.1 数据集介绍 1.2 CNN模型层结构 1.3 定义CNN模型 1.4 神经网络的前向传播过程 1.5 数据预处理 1.6 加载数据 1.7 初始化 1.8 模型训练过程 1.9 保存模型 二&#xff0c;模型测试 2.1 定义与训练时相同的CNN模型架构 2.2 图像的预处…...

    MYSQL创建索引的原则

    创建索引的原则包括&#xff1a; 表中的数据量超过10万以上时考虑创建索引。 选择查询频繁的字段作为索引&#xff0c;如查询条件、排序字段或分组字段。 尽量使用复合索引&#xff0c;覆盖SQL的返回值。 如果字段区分度不高&#xff0c;可以将其放在组合索引的后面。 对于…...

    运行Spark程序-在shell中运行

    Spark Shell运行程序步骤 启动Spark Shell 根据语言选择启动命令&#xff1a; Scala版本&#xff08;默认&#xff09;&#xff1a;执行spark-shellPython版本&#xff1a;执行pyspark 数据加载示例 读取本地文本文件&#xff1a; // Scala版本 val textData sc.textFile(…...

    idea Maven 打包SpringBoot可执行的jar包

    背景&#xff1a;当我们需要坐联调测试的时候&#xff0c;需要对接前端同事&#xff0c;则需要打包成jar包直接运行启动服务 需要将项目中的pom文件增加如下代码配置&#xff1a; <build><plugins><plugin><groupId>org.springframework.boot</gr…...

    HarmonyOs开发之——— ArkWeb 实战指南

    HarmonyOs开发之——— ArkWeb 实战指南 谢谢关注!! 前言:上一篇文章主要介绍HarmonyOs开发之———合理使用动画与转场:CSDN 博客链接 一、ArkWeb 组件基础与生命周期管理 1.1 Web 组件核心能力概述 ArkWeb 的Web组件支持加载本地或在线网页,提供完整的生命周期回调体…...

    国标GB/T 12536-90滑行试验全解析:纯电动轻卡行驶阻力模型参数精准标定

    摘要 本文以国标GB/T 12536-90为核心框架&#xff0c;深度解析纯电动轻卡滑行试验的完整流程与数据建模方法&#xff0c;提供&#xff1a; 法规级试验规范&#xff1a;从环境要求到数据采集全流程详解行驶阻力模型精准标定&#xff1a;最小二乘法求解 ( FAv^2BvC ) 的MATLAB实…...

    初识——QT

    QT安装方法 一、项目创建流程 创建项目 入口&#xff1a;通过Qt Creator的欢迎页面或菜单栏&#xff08;文件→新建项目&#xff09;创建新项目。 项目类型&#xff1a;选择「Qt Widgets Application」。 路径要求&#xff1a;项目路径需为纯英文且不含特殊字符。 构建系统…...

    几何_平面方程表示_点+向量形式

    三维平面方程可以写成&#xff1a; π : n ⊤ X d 0 \boxed{\pi: \mathbf{n}^\top \mathbf{X} d 0} π:n⊤Xd0​ &#x1f4d0; 一、几何直观解释 ✅ 平面是“法向量 平面上一点”定义的集合 一个平面可以由&#xff1a; 一个单位法向量 n ∈ R 3 \mathbf{n} \in \mat…...

    学习alpha

    (sign(ts_delta(volume, 1)) * (-1 * ts_delta(close, 1))) 这个先用sign操作符 sign.如果输入NaN则返回NaN 在金融领域&#xff0c;符号函数 sign(x) 与 “基础”&#xff08;Base&#xff09;的组合概念可结合具体场景解读&#xff0c;以下从不同金融场景分析其潜在意义&…...

    Java - Junit框架

    单元测试&#xff1a;针对最小的功能单元(方法)&#xff0c;编写测试代码对该功能进行正确性测试。 Junit&#xff1a;Java语言实现的单元测试框架&#xff0c;很多开发工具已经集成了Junit框架&#xff0c;如IDEA。 优点 编写的测试代码很灵活&#xff0c;可以指某个测试方法…...

    秒删node_modules[无废话版]

    “npm install”命令带来的便利和高效让人感到畅快&#xff0c;但删除依赖包时却可能带来诸多困扰。特别是在项目依赖关系较为复杂的情况下&#xff0c;node_modules文件夹的体积往往会膨胀至数百MB甚至几个GB&#xff0c;手动删除时进度条长时间转圈&#xff0c;令人感到焦虑和…...

    kkFileView文件文档在线预览镜像分享

    kkFileView为文件文档在线预览解决方案&#xff0c;该项目使用流行的spring boot搭建&#xff0c;易上手和部署&#xff0c;基本支持主流办公文档的在线预览&#xff0c;如doc,docx,xls,xlsx,ppt,pptx,pdf,txt,zip,rar,图片,视频,音频等等 开源项目地址 https://gitee.com/kek…...

    实例分割AI数据标注 ISAT自动标注工具使用方法

    文章目录 🌕ISAT安装和启动方法🌕下载和使用AI分割模型🌙SAM模型性能排行🌙手动下载sam模型 & sam模型下载路径🌕使用方法🌙从file中导入图片🌙点击左上角的图标进入分割模式🌙鼠标左键点击画面中的人则自动标注🌙点击右键该区域不标注🌙一个人一个人的…...

    Qt图表绘制(QtCharts)- 性能优化(13)

    文章目录 1 批量替换代替追加1.1 测试11.2 测试21.3 测试3 2 开启OpenGL2.1 测试12.2 测试22.3 测试32.4 测试4 更多精彩内容&#x1f449;内容导航 &#x1f448;&#x1f449;Qt开发 &#x1f448;&#x1f449;QtCharts绘图 &#x1f448;&#x1f449;python开发 &#x1f…...