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

面试算法高频08-动态规划-01

动态规划

递归知识要点

  1. 递归代码模板:提供递归代码的标准形式public void recur(int level, int param) ,包含终止条件(if (level> MAX_LEVEL))、当前层逻辑处理(process(level, param))、向下一层递归(recur(level: level +1, newParam))以及状态恢复(未完整代码呈现,但为重要环节),强调对该模板的记忆有助于构建递归算法逻辑。
  2. 递归状态树:递归状态树展示了问题逐步分解为子问题再求解的层级结构,直观呈现递归过程中各子问题间的关系,辅助理解递归算法的执行流程与问题处理机制。
  3. 人肉递归的问题及解决思路:人肉递归存在效率低、易出错的问题,人脑记忆的局限性使得在处理多层递归(如第三、四层)时难度加大。解决方法是寻找最近最简的方法,将问题拆解为可重复解决的子问题,运用数学归纳法思维,挖掘问题中的重复性,转化为计算机指令解决,避免过度依赖人肉递归。

动态规划知识要点

  1. 定义:动态规划是一种数学优化方法和计算机编程方法,由Richard Bellman在20世纪50年代提出。其核心是通过递归方式把复杂问题分解为简单子问题来简化求解过程,具有“分治 + 最优子结构”的特点,在多个领域广泛应用。
  2. 与递归、分治的关系:动态规划与递归、分治既有共性又有差异。共性在于都要找出重复子问题;差异在于动态规划具有最优子结构,并且在求解过程中能够淘汰次优解,从而提高算法效率,普通递归或分治可能不具备这些特性。
  3. 实例分析:以Fib(6)状态树为例,其中存在许多重复子状态(如f(4)f(3)f(2)多次出现)。利用动态规划淘汰次优解,可优化计算过程、避免重复计算,但可能使时间复杂度变为 n 2 n^2 n2,实际应用时需要权衡算法性能与复杂度。

题目练习

题目描述

使用动态规划(Dynamic Programming)方法求解斐波那契数列(Fibonacci Sequence)的第 n 项。斐波那契数列的定义为:

  • F(0) = 0
  • F(1) = 1
  • F(n) = F(n-1) + F(n-2)(当 n ≥ 2 时)
分析思路
1. 动态规划核心思想

斐波那契数列具有最优子结构重叠子问题,适合用动态规划求解:

  • 最优子结构F(n)F(n-1)F(n-2) 唯一确定。
  • 重叠子问题:递归求解时,F(n-1)F(n-2) 会被重复计算(如计算 F(6) 时,F(4) 会被计算两次)。动态规划通过存储中间结果避免重复计算,提升效率。
2. 状态定义

定义 dp[i] 表示斐波那契数列的第 i 项的值。

3. 状态转移方程

根据斐波那契数列定义,状态转移方程为:
[ dp[i] = dp[i-1] + dp[i-2] ]
初始条件:

  • dp[0] = 0
  • dp[1] = 1
4. 空间优化

常规动态规划需用数组存储所有中间状态(空间复杂度 O(n)),但由于 dp[i] 仅依赖前两项 dp[i-1]dp[i-2],可通过两个变量 prev1(存储 F(n-2))和 prev2(存储 F(n-1))迭代更新,将空间复杂度优化至 O(1)

最优解答(Python)
方法一:常规动态规划(数组存储中间状态)
def fib(n: int) -> int:if n <= 1:return ndp = [0] * (n + 1)dp[0], dp[1] = 0, 1for i in range(2, n + 1):dp[i] = dp[i-1] + dp[i-2]return dp[n]
方法二:空间优化动态规划(O(1) 空间)
def fib(n: int) -> int:if n <= 1:return nprev1, prev2 = 0, 1  # 对应 F(0) 和 F(1)for i in range(2, n + 1):current = prev1 + prev2  # 计算 F(i)prev1, prev2 = prev2, current  # 迭代更新前两项return prev2  # 最终 prev2 存储 F(n)
复杂度分析
  • 时间复杂度:两种方法均为 O(n),每个状态仅计算一次。
  • 空间复杂度
    • 方法一为 O(n)(存储数组 dp)。
    • 方法二为 O(1)(仅用两个变量迭代)。
关键点
  • 状态转移方程:明确子问题之间的关系,是动态规划的核心。
  • 边界条件:正确初始化 dp[0]dp[1],避免逻辑错误。
  • 空间优化:利用问题特性(仅依赖前两项),减少内存占用,提升效率。
示例验证

n = 6 时:

  • 常规方法:dp[2]=1, dp[3]=2, dp[4]=3, dp[5]=5, dp[6]=8,返回 8
  • 优化方法:通过迭代计算,最终 prev28,结果一致。

通过动态规划,斐波那契数列的求解效率从递归的指数级(O(2^n))提升至线性级(O(n)),是重叠子问题和最优子结构的经典应用。

题目描述(课件中的路径计数问题)

在一个 m×n 的网格 中,从左上角起点 (0, 0) 移动到右下角终点 (m-1, n-1),每次只能 向下(Row+1)或向右(Col+1) 移动一步。网格中某些单元格为 障碍物(非空地),若单元格 (i,j) 是障碍物,则无法通过。求从起点到终点的 路径总数

网格路径示意图

在这里插入图片描述

最优解答(Python)
def count_paths(grid: list[list[bool]]) -> int:m, n = len(grid), len(grid[0])dp = [[0] * n for _ in range(m)]dp[m-1][n-1] = 1 if not grid[m-1][n-1] else 0for i in range(m-1, -1, -1):for j in range(n-1, -1, -1):if i == m-1 and j == n-1:continueif grid[i][j]:dp[i][j] = 0continuedown = dp[i+1][j] if i+1 < m else 0right = dp[i][j+1] if j+1 < n else 0dp[i][j] = down + rightreturn dp[0][0]# 示例测试
if __name__ == "__main__":grid = [[False, False, False],[False, False, False],[False, False, False]]print(count_paths(grid))  # 输出: 6
答案解析
1. 动态规划核心思路(课件要点)
  • 状态定义dp[i][j] 表示从 (i,j) 到终点的路径数,障碍物单元格路径数为 0
  • 状态转移dp[i][j] = dp[i+1][j] + dp[i][j+1](下方和右方路径数之和),与课件中“累加关系”的状态转移方程一致。
  • 倒推计算:从终点向上、向左递推,避免起点边界特殊处理,符合课件中“从最下面依次往上”的思路。
2. 复杂度与关键点
  • 时间/空间复杂度均为 O(m×n),通过二维数组存储中间状态,确保每个单元格仅计算一次。
  • 障碍物判断直接决定当前单元格路径数是否为 0,是课件中“if a[i,j]=‘空地’”条件的代码实现。

该解答结合课件核心思想与图片可视化,清晰呈现动态规划在路径计数问题中的应用。

相关文章:

面试算法高频08-动态规划-01

动态规划 递归知识要点 递归代码模板&#xff1a;提供递归代码的标准形式public void recur(int level, int param) &#xff0c;包含终止条件&#xff08;if (level> MAX_LEVEL)&#xff09;、当前层逻辑处理&#xff08;process(level, param)&#xff09;、向下一层递归…...

【AI】以Llama模型为例学习如何进行LLM模型微调

以Llama模型为例学习如何进行LLM模型微调 推荐超级课程: 本地离线DeepSeek AI方案部署实战教程【完全版】Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速入门实战目录 以Llama模型为例学习如何进行LLM模型微调背景预训练微调全部微调参数高效微调低秩适配 (LoR…...

细说STM32单片机FreeRTOS任务管理API函数vTaskList()的使用方法

目录 一、函数vTaskList() 1、 函数说明 2、返回的字符串表格说明 3、函数的使用方法 二、 vTaskList()的应用示例 1、示例功能、项目设置 2、软件设计 &#xff08;1&#xff09;main.c &#xff08;2&#xff09;freertos.c &#xff08;3&#xff09;FreeRTOSConf…...

ffmpeg 添加 nvenc支持

运行以下命令检查当前 FFmpeg 是否支持 hevc_nvenc&#xff1a; ffmpeg -hide_banner -encoders | grep nvenc 若输出包含 hevc_nvenc&#xff0c;说明编码器已集成&#xff0c;问题出在驱动或参数配置若无输出&#xff0c;则需要手动编译 ffmpeg 安装显卡驱动、cuda和cudnn…...

锚定效应的应用-独立站优化价格打折显示-《认知偏差手册》

锚定效应的应用-独立站优化价格打折显示-《认知偏差手册》 先看结果&#xff1a;价格展示 https://atemplate.com/pricing 旧的打折价格展示 新的打折价格展示 锚定效应是什么&#xff1f; 人类在进行决策时&#xff0c;会过度偏重先前取得的资讯&#xff08;这称为锚点&…...

红宝书第四十九讲:XSS/CSRF攻击防御策略解析

红宝书第四十九讲&#xff1a;XSS/CSRF攻击防御策略解析 资料取自《JavaScript高级程序设计&#xff08;第5版&#xff09;》。 查看总目录&#xff1a;红宝书学习大纲 XSS&#xff08;跨站脚本&#xff09;&#xff1a;黑客把恶意代码塞进网页&#xff0c;当你打开页面时&am…...

Unity基于屏幕空间的鼠标拖动,拖动物体旋转

代码的核心在于&#xff0c;鼠标的屏幕偏移映射到物体的旋转角度&#xff0c;代码中是使用射线去检测的&#xff0c;检测帧间隔鼠标的位置对应物体上的旋转 未解决的问题&#xff1a;旋转都是相对的&#xff0c;怎么去处理&#xff0c;鼠标拖动物体&#xff0c;物体不动&#…...

Unity3D 测试驱动开发(TDD)框架设计

前言 针对Unity3D测试驱动开发&#xff08;TDD&#xff09;框架的设计&#xff0c;需要结合Unity引擎特性与TDD核心原则&#xff0c;构建可维护、高效且与开发流程深度集成的测试体系。以下是分层次的框架设计方案&#xff1a; 对惹&#xff0c;这里有一个游戏开发交流小组&a…...

Google Mock(GMock):C++单元测试的高效模拟框架详解

标题&#xff1a; Google Mock&#xff08;GMock&#xff09;&#xff1a;C单元测试的高效模拟框架详解 摘要&#xff1a; Google Mock&#xff08;GMock&#xff09;是C单元测试中的核心工具&#xff0c;能够高效隔离外部依赖并验证复杂交互逻辑。本文详细介绍了GMock的核心…...

智慧城市气象中台架构:多源天气API网关聚合方案

在开发与天气相关的应用时&#xff0c;获取准确的天气信息是一个关键需求。万维易源提供的“天气预报查询”API为开发者提供了一个高效、便捷的工具&#xff0c;可以通过简单的接口调用查询全国范围内的天气信息。本文将详细介绍如何使用该API&#xff0c;以及其核心功能和调用…...

vue3项目启动bug

项目场景&#xff1a; vue3 项目启动运行 问题描述 终端无法正常启动运行 C:/user/adminC:/user/admin> npm run dev > student_status_vue30.0.0 dev > vite原因分析&#xff1a; 暂无 解决方案&#xff1a; 在当前项目目录下运行&#xff1a; npx vite --host…...

逻辑回归 (Logistic Regression)

文章目录 逻辑回归 (Logistic Regression)问题的引出Sigmoid function逻辑回归的解释决策边界 (Decision boundary)逻辑回归的代价函数机器学习中代价函数的设计1. 代价函数的来源&#xff08;1&#xff09;从概率模型推导而来&#xff08;统计学习视角&#xff09;&#xff08…...

SLAM | 激光SLAM中的退化问题

在激光SLAM中,判断退化环境的核心是通过数学建模分析环境特征对位姿估计的约束能力。除了LOAM中提出的退化因子D外,还存在多种基于表达式和阈值设定的方法。以下是几种典型方法及其实现原理: 1. 协方差矩阵特征值分析 原理:通过分析点云协方差矩阵的特征值分布,判断环境中…...

【已更新】2025华中杯B题数学建模网络挑战赛思路代码文章教学:校园共享单车的调度与维护问题

完整内容请看文末最后的推广群 先展示问题一代码和结果、再给出四个问题详细的模型 import pandas as pd import numpy as np import matplotlib.pyplot as plt import seaborn as sns from matplotlib.font_manager import FontPropertiesfrom matplotlib import rcParams# 设…...

[特殊字符] 基于大模型的地理领域文档中英互译自动化方案

一、&#x1f4cc; 项目背景与挑战 在全球化商业环境中&#xff0c;跨国企业经常面临专业文档翻译的痛点&#xff1a; 传统方式效率低下&#xff1a;专业文档翻译需要专人耗时数小时甚至数天 专业术语准确性难保证&#xff1a;地理领域术语的特殊性 格式保持困难&#xff1a…...

破局遗留系统!AI自动化重构:从静态方法到Spring Bean注入实战

在当今快速发展的软件行业中,许多企业都面临着 Java 遗留系统的维护和升级难题。这些老旧系统往往采用了大量静态方法,随着业务的不断发展,其局限性日益凸显。而飞算 JavaAI 作为一款强大的 AI 工具,为 Java 遗留系统的重构提供了全新的解决方案,能够实现从静态方法到 Spring B…...

高度图(Heightmap)

高度图的数学组成与建模方法 高度图&#xff08;Heightmap&#xff09;是一种基于规则网格的地形表示方法&#xff0c;其数学本质是将三维地形简化为二维离散函数&#xff0c;通过高度值的存储和插值实现地形重建。以下从数学建模角度系统阐述其组成原理及关键技术。 一、基础…...

2025第十七届“华中杯”大学生数学建模挑战赛题目B 题 校园共享单车的调度与维护问题完整思路 模型 代码 结果分享

共享单车目前已成为不少大学校园内学生的重要通勤工具&#xff0c;给学生的出行带来了极大便利&#xff0c;但同时也产生了一些问题&#xff0c;如共享单车投放点位设计不合理&#xff0c;高峰期运力不足等。 某高校委托一公司在校园内投放了一批共享单车&#xff0c;经过一段时…...

ESP32-idf学习(一)搭建环境和点灯

一、前言 先说一下查到的数据&#xff08;不保证准确&#xff09;&#xff1a; 1、连续四年Wi-Fi MCU全球市场份额第一&#xff0c;产品应用于智能家居、工业自动化、医疗健康等泛IoT领域‌&#xff0c;2024 年营收突破 20 亿元&#xff08;同比 40%&#xff09;&#xff0c;…...

超详细VMware虚拟机扩容磁盘容量-无坑版

1.环境&#xff1a; 虚拟机&#xff1a;VMware Workstation 17 Pro-17.5.2 Linux系统&#xff1a;Ubuntu 22.04 LTS 2.硬盘容量 虚拟机当前硬盘容量180G -> 扩展至 300G 3.操作步骤 &#xff08;1&#xff09;在虚拟机关机的状态下&#xff0c;虚拟机硬盘扩容之前必…...

多线程(进阶续~)(内涵面试题)

目录 一、JUC 的常见类 1. Callable 接口 2. ReentrantLock ReentrantLock 的用法&#xff1a; ReentrantLock 和 synchronized 的区别&#xff1a; 何时使用何锁: 3. 原子类 4. 线程池 ExecutorService 和 Executors ThreadPoolExecutor 5. 信号量 Semaphore 6. C…...

OpenGL shader开发实战学习笔记:第十一章 立方体贴图和天空盒

1. 立方体贴图和天空盒 1.1. 什么是立方体贴图 立方体贴图&#xff08;Cube Map&#xff09;是一种纹理&#xff0c;它由六个纹理图像组成&#xff0c;每个纹理图像对应一个方向。这些方向通常是立方体的六个面&#xff0c;分别是“前面”&#xff0c;“后面”&#xff0c;“…...

双指针算法(二)

目录 一、力扣611——有效三角形的个数 二、牛客网3734——和为S的两个数字 三、力扣15——三数之和 四、力扣18——四数之和 一、力扣611——有效三角形的个数 题目如下&#xff1a; 这里我们先认识如何判断是个三角形&#xff0c;ab>c,ac>b,bc>a即为三角形 这里…...

docker Windows 存放位置

docker Windows 存放位置 镜像文件层可能是这 docker的overlay2中存的都是什么and如何清理/var/lib/docker/overlay2_docker overlay 是什么目录-CSDN博客 存的是我们的镜像文件和容器内的文件 \\wsl.localhost\docker-desktop\mnt\docker-desktop-disk\data\docker\overla…...

每日一题(小白)暴力娱乐篇31

首先分析一下题意&#xff0c;需要求出2024的因子&#xff0c;因为我们要求与2024互质的数字&#xff0c;为什么呢&#xff1f;因为我们要求互质说直白点就是我和你两个人没有中间人&#xff0c;我们是自然而然认识的&#xff0c;那我们怎么认识呢&#xff0c;就是直接见面对吧…...

FastAPI与SQLAlchemy数据库集成

title: FastAPI与SQLAlchemy数据库集成 date: 2025/04/17 15:33:34 updated: 2025/04/17 15:33:34 author: cmdragon excerpt: FastAPI与SQLAlchemy的集成通过创建虚拟环境、安装依赖、配置数据库连接、定义数据模型和实现路由来完成。核心模块包括数据库引擎、会话工厂和声…...

SQL刷题记录贴

1.题目&#xff1a;现在运营想要对用户的年龄分布开展分析&#xff0c;在分析时想要剔除没有获取到年龄的用户&#xff0c;请你取出所有年龄值不为空的用户的设备ID&#xff0c;性别&#xff0c;年龄&#xff0c;学校的信息。 错误&#xff1a;select device_id,gender,age,un…...

消息队列实际结点数与计数器不一致问题分析

问题描述 协议栈 PDCP线程任根据外部消息&#xff0c;维护一个链表式的PDCP PDU消息队列&#xff0c;以及一个变量count来记录消息队列中结点数。 当收到 从NG接口业务数据时&#xff0c;PDCP线程会向PDCP PDU消息队列中添加大量节点&#xff0c;消息队列的count值相应的增加…...

AI预测3D新模型百十个定位预测+胆码预测+去和尾2025年4月17日第55弹

从今天开始&#xff0c;咱们还是暂时基于旧的模型进行预测&#xff0c;好了&#xff0c;废话不多说&#xff0c;按照老办法&#xff0c;重点8-9码定位&#xff0c;配合三胆下1或下2&#xff0c;杀1-2个和尾&#xff0c;再杀6-8个和值&#xff0c;可以做到100-300注左右。 (1)定…...

C++23 新特性:std::size_t 字面量后缀 Z/z

在 C23 中&#xff0c;引入了一个非常实用的新特性&#xff1a;为 std::size_t 类型的字面量提供了新的后缀 Z 和 z。这一改进使得在代码中声明和使用 std::size_t 类型的字面量变得更加直观和便捷。 1. 背景与动机 在之前的 C 标准中&#xff0c;std::size_t 是一种非常常用…...

【裁员感想】

裁员感想 今天忽然感觉很emo 因为知道公司要裁员 年中百分之10 年末百分十10 我知道这个百分20会打到自己 所以还挺不开心的 我就想起 我的一个亲戚当了大学老师 我觉得真的挺好的 又有寒暑假 又不是很累 薪资也不低 又是编制 同时也觉得自己很失败 因为对自己互联网的工作又…...

CSS例子 > 图片瀑布流布局(vue2)

<template><div class"container"><!-- 临时容器用于计算高度 --><div v-if"!isLayoutReady" class"temp-container"><divv-for"(item, index) in list":key"temp- index":ref"(el) > …...

Python 获取淘宝券后价接口的详细指南

在电商领域&#xff0c;淘宝作为国内领先的电商平台&#xff0c;提供了丰富的商品和优惠活动。对于开发者来说&#xff0c;获取淘宝商品的券后价是一个极具价值的功能&#xff0c;可以帮助用户更好地进行购物决策&#xff0c;同时也为相关应用和服务提供了数据支持。本文将详细…...

零服务器免备案!用Gitee代理+GitHub Pages搭建个人博客:绕过443端口封锁实战记录

#GitHub Pages #Gitee代理 #SSH密钥管理 #Jekyll博客 #网络穿透 场景&#xff1a;自己的电脑没有添加github的ssh代理&#xff0c;只有gitee的代理 实现效果&#xff0c;在公网可以运行个人博客。在本地更改内容后公网同步更新。 最开始的模板 最终实现的博客模板&#xff1…...

如何新建一个空分支(不继承 master 或任何提交)

一、需求分析&#xff1a; 在 Git 中&#xff0c;我们通常通过 git branch 来新建分支&#xff0c;这些分支默认都会继承当前所在分支的提交记录。但有时候我们希望新建一个“完全干净”的分支 —— 没有任何提交&#xff0c;不继承 master 或任何已有内容&#xff0c;这该怎么…...

[终极版]Javascript面试全解

this指向 执行上下文 是代码执行时的运行环境作用域 是变量和函数的可访问性规则&#xff08;静态&#xff09;&#xff1b;全局、函数和块状&#xff1b;内层可访问外层&#xff0c;外层不能访问内层词法环境 是实现作用域的引擎内部机制&#xff08;静态&#xff09; 执行上…...

day30图像处理OpenCV

文章目录 一、图像预处理9. 图像掩膜9.1 制作掩膜9.2 与运算1.原理2.语法 9.3 颜色替换9.4案例 一、图像预处理 9. 图像掩膜 创建的掩膜方便我们对目标区域进行操作。 9.1 制作掩膜 掩膜通常是一个二值化图像&#xff0c;并且与原图像的大小相同。其中目标区域被设置为1&am…...

蓝桥杯 10.拉马车

拉马车 原题目链接 题目描述 小时候你玩过纸牌游戏吗&#xff1f; 有一种叫做 “拉马车” 的游戏&#xff0c;规则简单但非常吸引小朋友。 游戏规则简述如下&#xff1a; 假设参加游戏的小朋友是 A 和 B&#xff0c;游戏开始时&#xff0c;他们得到的随机纸牌序列如下&am…...

Java学习总结-Junit单元测试

单元测试&#xff1a; 就是针对最小功能的单元&#xff1a;方法&#xff0c;编写测试代码对其进行正确性测试。 之前我们怎么测试的&#xff1a;在main方法中调用其他方法&#xff0c;一个方法测试失败可能导致其他方法得不到测试&#xff0c;无法得到测试报告。 Junit单元测…...

代理IP:城市文化IP打造的隐形加速器

目录 一、解码代理IP&#xff1a;数字时代的"变身术" 1.1 工作原理探秘 1.2 主要类型对比 二、城市文化IP的打造密码 2.1 核心要素拆解 2.2 成功案例启示 三、代理IP的五大赋能场景 3.1 文化数据采集 3.2 目标市场定位 3.3 品牌传播突破 3.4 版权保护监控 …...

链式数据存储系统

目录 系统说明 服务端的模块设计 存储数据说明 服务端设计-程序入口&#xff08;main&#xff09; 数据库的连接-mysql包的编写 数据的加密-hash文件的编写 数据传递格式-proto文件的编写 具体实现方法-controller包的编写 日志的打印-logs包的编写 扩展服务端 系统说…...

《理解 Java 泛型中的通配符:extends 与 super 的使用场景》

大家好呀&#xff01;&#x1f44b; 今天我们要聊一个让很多Java初学者头疼的话题——泛型通配符。别担心&#xff0c;我会用最通俗易懂的方式&#xff0c;带你彻底搞懂这个看似复杂的概念。准备好了吗&#xff1f;Let’s go! &#x1f680; 一、为什么我们需要泛型通配符&…...

Scala 入门指南

Scala 入门指南 目录 简介环境搭建基础语法面向对象编程函数式编程集合模式匹配特质隐式转换并发编程与 Java 互操作最佳实践常见问题 简介 Scala 是一种多范式编程语言&#xff0c;结合了面向对象编程和函数式编程的特性。它运行在 JVM 上&#xff0c;与 Java 完全兼容&am…...

GESP2025年3月认证C++八级( 第一部分选择题(11-15))

杨辉三角形&#xff1a; #include <iostream> using namespace std;#define N 35 // 最多支持输出 35 行 int a[N]; // 一维数组&#xff0c;用于存储当前行的杨辉三角数int main() {int n;cin >> n; // 输入要输出的行数for (int i 0; i < n; i) {a[i] …...

Dynamics 365 Business Central Master Data Managerment Setup 主数据管理

#Dynamics 365 BC ERP# #Navision# 引言 在BC中除了之前有一个章节提到的用Code 同步资料&#xff0c; 也可以用内置主数据管理功能来同步资料。 Master Data Management Setup 设置Source Company 为 主要管理主数据的公司 Synchronization Tables 设置需要同步的Table 这…...

深入理解 requestIdleCallback 与大数据加载优化

使用 requestIdleCallback 优化大批量 DOM 操作 —— 以加载 100 万条数据为例 在前端开发中&#xff0c;如果你尝试在短时间内往 DOM 中添加大量元素&#xff0c;比如一次性插入 100 万条数据&#xff0c;页面极有可能卡顿甚至直接崩溃。为了解决这一性能问题&#xff0c;我们…...

【MySQL】索引运算与NULL值问题详解:索引字段应尽量 NOT NULL ,NULL值不能参与部分索引运算

索引运算与NULL值问题详解 不能参与的"部分索引运算"指什么&#xff1f; 这里的"部分索引运算"指的是索引列在某些特定操作或条件下无法被MySQL优化器有效利用的情况&#xff0c;特别是当字段包含NULL值时。主要包括以下几种情况&#xff1a; 1. 比较运…...

STM32 F103 标准库CH452A 4线 数码管驱动芯片显示数码管

公司生产测试需要统一去检查这版CH452A的好坏&#xff0c;网上找了一下没有现成可以用的4线CH452A的驱动程序&#xff0c;所以直接就肝了移植官方的51程序到stm32上面去&#xff0c;亲测可以使用&#xff01;&#xff01; 文末有代码 测试图片&#xff1a; 如你所见我测了一堆…...

Vue 和 Spring boot 和 Bean 不同生命周期

一、Vue 组件生命周期 父子组件生命周期顺序&#xff1a; 创建时&#xff1a; 父 beforeCreate → 父 created → 父 beforeMount → 子组件生命周期 → 父 mounted 更新时&#xff1a; 父 beforeUpdate → 子组件更新 → 父 updated。 销毁时&#xff1a; 父 beforeDestroy…...

期货数据API对接实战指南

一、期货数据接口概述 StockTV提供全球主要期货市场的实时行情与历史数据接口&#xff0c;覆盖以下品种&#xff1a; 商品期货&#xff1a;原油、黄金、白银、铜、天然气、农产品等金融期货&#xff1a;股指期货、国债期货特色品种&#xff1a;马棕油、铁矿石等区域特色期货 …...