Python人工智能算法 模拟退火算法:原理、实现与应用
模拟退火算法:从物理启发到全局优化的深度解析
一、算法起源与物理隐喻
模拟退火算法(Simulated Annealing, SA)起源于20世纪50年代的固体退火理论,其核心思想可追溯至Metropolis等人提出的蒙特卡罗模拟方法。1983年,Kirkpatrick等人首次将这一物理现象映射到组合优化领域,通过模拟金属从高温逐渐冷却的过程,实现对复杂解空间的全局搜索。
1.1 物理退火过程的数学映射
- 温度参数(T):控制算法的探索能力,高温时允许接受劣解以跳出局部最优,低温时聚焦于局部精细优化。
- 能量函数(E):对应优化问题的目标函数,如旅行商问题(TSP)中的路径总距离。
- 状态转移(ΔE):新解与当前解的能量差,决定是否接受新解。
二、核心原理与数学模型
2.1 Metropolis接受准则
当生成新解的能量差 Δ E > 0 \Delta E > 0 ΔE>0时,以概率
P = exp ( − Δ E k T ) P = \exp\left(-\frac{\Delta E}{kT}\right) P=exp(−kTΔE)
接受该解,其中 k k k为玻尔兹曼常数, T T T为当前温度。该概率随温度降低呈指数衰减,模拟固体在高温时更容易接受能量升高的状态。
2.2 冷却进度表设计
冷却进度表(Cooling Schedule)是算法的关键控制参数,包括:
- 初始温度( T 0 T_0 T0):通常设置为能使90%以上的新解被接受的值,例如
T 0 = Δ E ln ( 0.9 ) T_0 = \frac{\Delta E}{\ln(0.9)} T0=ln(0.9)ΔE - 降温策略:
- 几何降温: T k + 1 = α ⋅ T k T_{k+1} = \alpha \cdot T_k Tk+1=α⋅Tk, α ∈ [ 0.8 , 0.99 ] \alpha \in [0.8, 0.99] α∈[0.8,0.99]
- 线性降温: T k + 1 = T k − Δ T T_{k+1} = T_k - \Delta T Tk+1=Tk−ΔT
- 自适应降温:根据搜索状态动态调整降温速率
- 终止温度( T min T_{\text{min}} Tmin):通常设为接近0的极小值,如 10 − 8 10^{-8} 10−8
- 马尔可夫链长度(L):每个温度下的迭代次数,建议取问题规模的5-10倍
三、算法流程与实现细节
3.1 标准流程框架
初始化:生成初始解S₀,设置T₀、α、L、T_min
当前解S = S₀,最优解S* = S₀
while T > T_min:for i in 1 to L:生成邻域解S'计算ΔE = E(S') - E(S)if ΔE < 0 or random() < exp(-ΔE/(kT)):S = S'if E(S) < E(S*):S* = ST = α * T
return S*
3.2 关键技术点解析
- 邻域结构设计:
- TSP问题中常用2-opt交换(交换两条边)或3-opt变换,邻域规模为 O ( n 2 ) O(n^2) O(n2)
- 连续优化问题可采用高斯扰动:
S ′ = S + σ ⋅ N ( 0 , 1 ) S' = S + \sigma \cdot \mathcal{N}(0,1) S′=S+σ⋅N(0,1)
- 初始解构造:
- 随机生成(适用于小规模问题)
- 启发式方法(如最近邻法求解TSP)
- 终止条件优化:
- 结合迭代次数与停滞代数(如连续50代未更新最优解则终止)
四、典型应用场景
4.1 组合优化领域
- 旅行商问题(TSP):通过随机交换城市顺序,逐步优化路径长度。实验表明,模拟退火在20城市规模下可找到接近最优解的路径,平均误差小于5%
- 车辆路径规划(CVRP):处理带容量限制的多车辆调度,邻域操作包括路线分割与合并
- 作业车间调度:优化工序顺序以减少最大完工时间,禁忌表记录机器分配的调整
4.2 机器学习与数据科学
- 超参数调优:将学习率、网络层数等参数的调整视为状态转移,结合Metropolis准则实现全局搜索
- 特征选择:通过添加/删除特征的操作,避免陷入局部最优特征子集
4.3 工程设计与资源分配
- 电路布局优化:减少芯片引脚连线长度,邻域操作为模块位置的随机移动
- 无线传感器网络覆盖:优化节点部署位置,禁忌表记录节点的移动方向和距离
五、算法实现:以TSP问题为例
import math
import randomdef create_initial_route(num_cities):"""生成随机初始路径"""route = list(range(num_cities))random.shuffle(route)return routedef calculate_distance(route, distance_matrix):"""计算路径总距离"""return sum(distance_matrix[route[i]][route[i+1]] for i in range(len(route)-1))def generate_neighbor(route):"""生成邻域解(2-opt交换)"""i, j = sorted(random.sample(range(len(route)), 2))new_route = route[:i] + route[i:j+1][::-1] + route[j+1:]return new_routedef simulated_annealing(tsp_matrix, initial_temp=1000, cooling_rate=0.95, n_iterations=1000):num_cities = len(tsp_matrix)current_route = create_initial_route(num_cities)best_route = current_route.copy()best_distance = calculate_distance(current_route, tsp_matrix)current_temp = initial_tempfor _ in range(n_iterations):neighbor = generate_neighbor(current_route)neighbor_distance = calculate_distance(neighbor, tsp_matrix)delta_e = neighbor_distance - best_distanceif delta_e < 0 or random.random() < math.exp(-delta_e / current_temp):current_route = neighborif neighbor_distance < best_distance:best_route = neighbor.copy()best_distance = neighbor_distancecurrent_temp *= cooling_rateif current_temp < 1e-8:breakreturn best_route, best_distance# 示例运行
if __name__ == "__main__":# 生成10城市的随机距离矩阵num_cities = 10distance_matrix = [[0]*num_cities for _ in range(num_cities)]for i in range(num_cities):for j in range(i+1, num_cities):dist = random.randint(10, 100)distance_matrix[i][j] = distance_matrix[j][i] = distbest_route, best_dist = simulated_annealing(distance_matrix)print(f"最优路径: {best_route}")print(f"最短距离: {best_dist}")
六、优缺点对比与适用边界
优点 | 缺点 |
---|---|
1. 理论上可收敛到全局最优解(在无限迭代下) 2. 对初始解不敏感,允许一定概率接受劣解 3. 适用于离散与连续优化问题 | 1. 计算复杂度高( O ( n 2 ) ∼ O ( n 3 ) O(n^2)\sim O(n^3) O(n2)∼O(n3)) 2. 参数敏感性强(初始温度、降温速率影响显著) 3. 难以处理高维复杂问题 |
适用场景:
- 目标函数不可微或存在多个局部最优(如TSP、VRP)
- 解空间规模中等(100-1000维),且允许一定计算时间的场景
- 传统优化方法失效的NP难问题
七、工程优化策略
7.1 参数调优技巧
- 初始温度设定:
- 经验公式:
T 0 = Δ E ln ( 0.9 ) T_0 = \frac{\Delta E}{\ln(0.9)} T0=ln(0.9)ΔE
其中 Δ E \Delta E ΔE为随机生成100个邻域解的平均能量差 - 动态调整:若连续10代未更新最优解,自动将初始温度提高20%
- 经验公式:
- 降温速率优化:
- 前期采用快速降温( α = 0.9 \alpha=0.9 α=0.9)以快速缩小搜索范围,后期切换为慢速降温( α = 0.99 \alpha=0.99 α=0.99)以精细优化
7.2 混合算法设计
- 与遗传算法结合:利用遗传算法的交叉变异生成初始解池,再通过模拟退火进行局部优化
- 与禁忌搜索结合:用禁忌表记录近期移动,避免重复搜索,同时保留模拟退火的概率接受机制
7.3 并行化加速
- 多线程并行:同时运行多个模拟退火实例,共享最优解
- GPU加速:利用CUDA实现邻域解生成与接受概率计算的并行化
八、理论分析与收敛性证明
8.1 渐近收敛性
在满足以下条件时,模拟退火算法以概率1收敛到全局最优解:
- 初始温度足够高
- 降温速率足够缓慢(如 T k = T 0 ln ( k + 1 ) T_k = \frac{T_0}{\ln(k+1)} Tk=ln(k+1)T0)
- 每个温度下的迭代次数趋于无穷大
8.2 收敛速度分析
- 最优解的收敛速度与冷却进度表的参数密切相关。几何降温策略( α = 0.95 \alpha=0.95 α=0.95)在多数情况下可在 O ( 10 4 ) O(10^4) O(104)次迭代内达到满意解
- 对于大规模问题,可采用自适应降温策略,根据搜索状态动态调整温度下降速率
九、实践经验与避坑指南
- 邻域结构选择:
- 对于TSP问题,2-opt邻域的计算复杂度为 O ( n 2 ) O(n^2) O(n2),适合城市数 n ≤ 1000 n\leq 1000 n≤1000的场景;3-opt邻域复杂度为 O ( n 3 ) O(n^3) O(n3),适用于 n ≤ 200 n\leq 200 n≤200的高精度需求
- 参数调试步骤:
- 固定冷却速率 α = 0.95 \alpha=0.95 α=0.95,调整初始温度 T 0 T_0 T0,直到算法在100次迭代内收敛
- 固定 T 0 T_0 T0,调整 α \alpha α,观察收敛曲线的平滑度
- 结果验证:
- 对小规模问题,对比模拟退火结果与精确算法(如动态规划)的解,评估误差范围
- 对大规模问题,采用多组不同初始解运行算法,验证解的稳定性
十、总结
模拟退火算法通过模拟物理退火过程,在复杂解空间中实现了全局搜索与局部优化的平衡。其核心优势在于理论上的全局收敛性和对初始解的低依赖性,使其成为解决NP难问题的首选方案之一。尽管存在参数调优和计算效率的挑战,但通过合理设计冷却进度表、邻域结构和混合策略,能够在工程实践中发挥重要作用。对于旅行商问题、超参数调优、电路布局等典型场景,模拟退火算法仍是兼具理论深度与实用价值的优选方案。
相关文章:
Python人工智能算法 模拟退火算法:原理、实现与应用
模拟退火算法:从物理启发到全局优化的深度解析 一、算法起源与物理隐喻 模拟退火算法(Simulated Annealing, SA)起源于20世纪50年代的固体退火理论,其核心思想可追溯至Metropolis等人提出的蒙特卡罗模拟方法。1983年,…...
服务器网络配置 netplan一个网口配置两个ip(双ip、辅助ip、别名IP别名)
文章目录 问答 问 # This is the network config written by subiquity network:ethernets:enp125s0f0:dhcp4: noaddresses: [192.168.90.180/24]gateway4: 192.168.90.1nameservers:addresses:- 172.0.0.207- 172.0.0.208enp125s0f1:dhcp4: trueenp125s0f2:dhcp4: trueenp125…...
FTP与NFS服务详解
一、FTP服务 (一)Linux下FTP客户端管理工具 1. ftp工具 安装命令:yum install ftp -y连接服务器:ftp 服务器IP,输入账号密码登录。常用命令: 命令说明ls查看远程目录文件put上传单个文件到远程服务器get…...
算法中的数学:欧拉函数
1.相关定义 互质:a与b的最大公约数为1 欧拉函数:在1~n中,与n互质的数的个数就是欧拉函数的值 eg: n1时,欧拉函数的值为1,因为1和1是互质的 n2是,值为2,因为1和2都是互质的 积性函数&…...
如果有三个服务实例部署在三台不同的服务器上,这三个服务实例的本地缓存,是存储一模一样的数据?还是各自只存一部分?
✅ 答案是:通常每个服务实例都会独立地缓存它自己访问过的数据,这些数据可能是相同的,也可能是不同的,取决于请求的内容。 📌 举个例子说明 假设你有一个商品详情页的服务,部署了 3 个服务实例(…...
Coze工作流-选择器的用法
上集回顾 上集教程我们学习了什么是变量以及变量类型的用法。即什么时候用什么变量类型 教程简介 本教程将带大家学习工作流的选择和问答模块 工作流类型选择 在Coze中,工作流是智能体的核心逻辑单元。根据任务复杂度,可选择两种模式: 类…...
《AI工程技术栈》:三层结构解析,AI工程如何区别于ML工程与全栈工程
每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…...
uni-app使用大集
1、手动修改页面标题 uni.setNavigationBarTitle({title: 修改标题 }); 2、单选 不止有 radio-group,还有 uni-data-checkbox 数据选择器 <!-- html部分 --> <uni-data-checkbox v-model"sex" :localdata"checkboxList"></u…...
链表day3
链表定义 struct ListNode{int val;ListNode *next; //next是一个指针变量,存储的是地址,是ListNode类型的地址ListNode(int x) : val(x),next(nullptr){} //也就是说ListNode必须接受一个int x,next指针默认为nullptr,值由外部指…...
C++23关联容器的异质擦除重载 (P2077R2)介绍
文章目录 一、基本概念二、原理重载机制类型转换 三、优势提高查找效率提升程序整体性能避免不必要的初始化确保系统实时性 四、应用场景高性能计算大型对象管理实时系统 五、代码示例六、相关图片材料结构与微观图像半导体研究图示与图表科学图表芯片与电路板 一、基本概念 在…...
Flink架构概览,Flink DataStream API 的使用,FlinkCDC的使用
一、Flink与其他组件的协同 Flink 是一个分布式、高性能、始终可用、准确一次(Exactly-Once)语义的流处理引擎,广泛应用于大数据实时处理场景中。它与 Hadoop 生态系统中的组件可以深度集成,形成完整的大数据处理链路。下面我们从…...
AI加速芯片全景图:主流架构和应用场景详解
目录 一、为什么AI芯片如此重要? 二、主流AI芯片架构盘点 三、不同芯片在训练与推理中的部署逻辑 四、真实应用案例解读 五、AI芯片发展趋势预测 AI芯片的选择,是AI系统能否高效运行的关键。今天笔者就从架构角度出发,带你系统了解主流AI加速芯片的种类、优劣对比及实际…...
Ubuntu22.04 系统安装Docker教程
1.更新系统软件包 #确保您的系统软件包是最新的。这有助于避免安装过程中可能遇到的问题 sudo apt update sudo apt upgrade -y 2.安装必要的依赖 sudo apt install apt-transport-https ca-certificates curl software-properties-common -y 3.替换软件源 原来/etc/apt/s…...
更新ubuntu软件源遇到GPG error
BUG背景 执行sudo apt update后遇到类似下列报错: E: The repository https://download.docker.com/linux/ubuntu bionic Release no longer has a Release file. N: Updating from such a repository cant be done securely, and is therefore disabled by defau…...
vue调后台接口
1.1 什么是 axios Axios 是一个基于 promise 的 HTTP 库,可以用来发送网络请求。它可以在浏览器和 node.js 中使用,本质上是对原生 XMLHttpRequest 的封装,符合最新的 ES 规范,支持 Promise API,能够拦截请求和响应&am…...
Ubuntu学习记录
冷知识补充 1.VMware官网安装后,会有两个软件,一个收费(pro)(功能更多,可以一次运行多个虚拟机)(尽管2024年最新版本的也免费了)一个免费(player)。 2.ubuntu打开终端快捷键:ctrlal…...
【音频】如何解析mp3文件
解析和播放MP3文件涉及两个主要步骤:解码(将MP3压缩数据转换为原始PCM音频)和播放(将PCM数据通过音频设备输出)。以下是不同平台和编程语言的实现方法: 一、MP3文件结构基础 MP3文件由多个**帧(Frame)**组成,每帧包含固定时长的音频数据(通常为26ms)。每个帧包含:…...
学习笔记:黑马程序员JavaWeb开发教程(2025.4.9)
12.16 异常处理 定义一个类,加上注解RestControllerAdvice,即定义了一个全局异常处理器 再方法上加上注解ExceptionHandler,通过注解当中的value属性来指定捕获那个类型的异常 完成Filter、interceptor、异常处理代码实操 Filter Filter里…...
【音频】wav文件如何解析编码格式(压缩格式)?
要确定一个WAV文件的编码格式,可以通过以下几种方法实现,包括使用操作系统自带工具、专业音频软件或编程解析文件头信息。以下是详细说明: 一、通过文件属性查看(Windows/macOS) 1. Windows系统 步骤: 右…...
【Django系统】Python+Django携程酒店评论情感分析系统
Python Django携程酒店评论情感分析系统 项目概述 这是一个基于 Django 框架开发的酒店评论情感分析系统。系统使用机器学习技术对酒店评论进行情感分析,帮助酒店管理者了解客户反馈,提升服务质量。 主要功能 评论数据导入:支持导入酒店…...
OpenCv高阶(十六)——Fisherface人脸识别
文章目录 前言一、Fisherface人脸识别原理1. 核心思想:LDA与Fisher准则2. 实现步骤(1) 数据预处理(2) 计算类内散布矩阵 SW对每个类别(每个人)计算均值向量 μi:(3) 计算类间散布矩阵 SB(4) 求解投影矩阵 W(5) 降维与分类 3. Fish…...
数据库与Redis数据一致性解决方案
在写数据时保证 Redis 和数据库数据一致,可采用以下方案,需根据业务场景权衡选择: 1. 先更新数据库,再更新 Redis 步骤: 写入 / 更新数据库数据。删除或更新 Redis 缓存。适用场景:读多写少,对缓存一致性要求不高(短暂不一致可接受)。风险:若第二步失败,导致缓存与…...
Python面试题
Python面试题 Python面试题回答1. Python面向对象的三个特征?多态如何实现和使用2. is 和 的区别?3. GIL了解吗?说说4. 可变类型和不可变类型?5. yield用法?6. 深拷贝和浅拷贝区别?7. Python中的线程8. 生…...
力扣周赛置换环的应用,最少交换次数
置换环的基本概念 置换环是排列组合中的一个概念,用于描述数组元素的重排过程。当我们需要将一个数组转换为另一个数组时,可以把这个转换过程分解为若干个 “环”。每个环代表一组元素的循环交换路径。 举个简单例子 假设原数组 A [3, 2, 1, 4]&…...
差分数组 - 对区间内元素的统一操作
目录 概念 题单 1 拼车 2 将区间分为最少组数 3 字母移位 4 使数组中的所有元素都等于零 5 零数组变换Ⅰ 6 最大化城市的最小电量 概念 差分数组,顾名思义,就是由原数组的相邻元素作差而得到的差值组成的新的数组。 对于原数组 a [ 1 , 3 , 5 …...
线上问题排查
一:CPU飙高问题排查过程 遇到这种问题,首先是登录到服务器,看一下具体情况。 定位进程:top命令,查看CPU占用情况定位线程:top -Hp 1893命令,查看各个线程的CPU使用情况定位代码:pr…...
计及可再生能源不确定性的经济优化调度方法
目前,计及可再生能源不确定性的经济调度方法主要有随机优化、鲁棒优化和区间优化。 随机优化:可再生能源输出被定义为一个已知概率分布的随机变量。 难以同时保证计算精度和效率。 1-场景法 场景生成 基于随机变量概率分布进行采样:蒙特…...
支持向量机(SVM):分类与回归的数学之美
在机器学习的世界里,支持向量机(Support Vector Machine,简称 SVM)是一种极具魅力且应用广泛的算法。它不仅能有效解决分类问题,在回归任务中也有着出色的表现。下面,就让我们深入探索 SVM 如何在分类和回归…...
用户刷题记录日历——签到表功能实现
MySQL实现 在数据库中设计一张签到表,记录用户每次签到的日期及其他相关信息。然后通过时间范围查询得到用户的签到记录。 CREATE TABLE user_sign_in (id BIGINT AUTO_INCREMENT PRIMARY KEY, -- 主键,自动递增userId BIGINT NOT NULL, …...
C语言中的内存函数
目录 1 memcpy()函数的基本信息及功能(1) void * destination(2) const void * source(3) size_t num 1.2 memcpy()函数实战演练1.3 memcpy()函数的模拟实现1.3.1 my_memcpy()函数定义及参数1.3.2 my_memcp…...
本特利内华达330103-00-03-05-02-05毫米接近传感器
描述 3300 XL 8 mm近程传感器系统包括:一个3300 XL 8 mm探头、一根3300 XL延长电缆1和一个3300 XL近程传感器2。 该系统提供的输出电压与探针尖端和观察到的导电表面之间的距离成正比,可以测量静态(位置)和动态(振动)值。该系统的主要应用是流体膜轴承机器的振动和位…...
啤酒游戏与系统思考
今天,与上海地产集团的伙伴们一同体验经典的系统思考沙盘模拟——“啤酒游戏”。虽然大家身处房地产行业,但也会惊讶地发现,啤酒游戏的核心理念对任何行业都适用,尤其是站在全局的角度,做出精准决策。 每次进行啤酒游戏…...
id分页遍历数据漏行问题
令入参id为0 while(true){ select * from table where id>#{id} order by id asc limit 100; 取结果集中最大id作为下次查询的入参 其他操作 } 这个算法一般没问题,但在主从数据系统中,主库写,查询从库遍历数据时,出现了…...
【Vue3】Vue3工程的创建 及 开发者工具的安装
目录 一、创建Vue3工程的方式 方法一 方法二 二、区分Vue3 和 Vue2的构建 观察main.js vue3不向下兼容,也就是说Vue3不支持Vue2的写法! JavaScript 的模块导入有两种常见写法: 三、安装Vue3的开发者工具 总结不易~本章节对我有很大的…...
docker exec -it abc bash
当然可以!让我们详细解析一下 docker exec -it abc bash 这个命令的各个部分及其作用。 命令概述 docker exec -it abc bash这个命令用于在已经运行的 Docker 容器 abc 中启动一个新的交互式终端会话。具体来说,它会执行容器内的 bash 命令,…...
基于AI大语言模型的历史文献分析在气候与灾害重建中的技术-以海南岛千年台风序列重建为例
随着人工智能技术的飞速发展,大语言模型如GPT、BERT等在自然语言处理领域取得了显著成果。这些模型不仅提高了文本数据的处理和理解效率,还为历史灾害研究提供了全新的视角和方法。本文将深入探讨基于AI大语言模型的历史文献分析在气候与灾害重建领域中的…...
【最细】自动化测试-解决日志问题,一文贯通...
目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 持续集成的自动化…...
PromptIDE:一款强大的AI提示词优化工具
今天向大家推荐一款专业且免费的AI提示词工具——PromptIDE。作为AI领域从业者,我们都深知提示词质量对模型输出的重要性,而这款工具正是为解决这一痛点而生。 核心功能解析 1、提示词优化 简单输入你的需求描述,点击AI生成提示词…...
f-string 高效的字符串格式化
f-string,称为格式化字符串常量(formatted string literals),是Python3.6新引入的一种字符串格式化方法,该方法源于PEP 498 – Literal String Interpolation,主要目的是使格式化字符串的操作更加简便。 p…...
Powershell及命令行文章合集(不定期更新)
一、Powershell: 1.Powershell中常用命令和常用属性:https://blog.csdn.net/humors221/article/details/147978718 2.Powershell数值应用讲解:https://blog.csdn.net/humors221/article/details/142897029 3.PowerShell 抓取网络日志:https://blog.csdn.net/humors221/artic…...
leetcode hot100刷题日记——8.合并区间
class Solution { public:vector<vector<int>> merge(vector<vector<int>>& intervals) {if(intervals.empty()){//复习empty函数啊,日记1有的return {};}// 按照区间的起始位置进行排序sort(intervals.begin(), intervals.end());vect…...
基于moonshot模型的Dify大语言模型应用开发核心场景
基于moonshot模型的Dify大语言模型应用开发核心场景学习总结 一、Dify环境部署 1.Docker环境部署 这里使用vagrant部署,下载vagrant之后,vagrant up登陆,vagrant ssh,在vagrant 中使用 vagrant centos/7 init 快速创建虚拟机 安装…...
系统设计应优先考虑数据流还是控制流?为什么优先考虑数据流?数据流为主、控制流为辅的架构原则是什么?控制流优先会导致哪些问题?
在当代软件工程的复杂演化中,每个现代系统,不论是处理金融交易的平台、智能家居系统,还是自动驾驶系统,都面临同一个核心问题:设计者该以“数据流”为主导,还是以“控制流”为主导? 在系统设计过程中,工程师所面对的核心问题不仅是代码的堆叠与组织,更是信息流动模式…...
Redis Cluster动态扩容:架构原理与核心机制解析
一、哈希槽的数学本质与拓扑重构 核心图示:哈希槽分配演变 #mermaid-svg-YmcBfipoPA8LvxYF {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-YmcBfipoPA8LvxYF .error-icon{fill:#552222;}#mermaid-svg-Y…...
高考之外,英国国际大一:开启本科留学新征程
在竞争激烈的教育赛道上,高考一直被视为通向高等学府的重要关卡。然而,当千军万马挤在国内升学这座独木桥时,越来越多有远见的学生和家长将目光投向海外,英国本科留学凭借其灵活的录取机制和多元的升学路径,成为众多学…...
UML 图的细分类别及其应用
统一建模语言(UML,Unified Modeling Language)是一种用于软件系统建模的标准化语言,广泛应用于软件工程领域。UML 图分为多种类别,每种图都有其特定的用途和特点。本文将详细介绍 UML 图的细分类别,包括 类…...
Android10如何设置ro.debuggable=1?
说明:仅供学习使用,请勿用于非法用途,若有侵权,请联系博主删除 作者:zhu6201976 目录 一、背景 二、如何解决? 三、操作步骤 一、背景 Android 10 开始的限制:ro.debuggable 是只读属性 从 …...
每日算法刷题计划Day12 5.21:leetcode不定长滑动窗口求最短/最长3道题,,用时1h40min(有点长了)
求最短/最小 一般题目都有「至少」的要求。 想窗口成立的条件,right右移增强条件,然后while循环left右移最终破坏条件 模版套路 在while循环内更新答案 class Solution { public:int minSubArrayLen(int target, vector<int>& nums) {int …...
JUC高并发编程
1. JUC概述 1.1 什么是JUC JUC时java.util.concurrent工具包的简称。这是一个处理线程的工具包,JDK1.5开始出现的。 1.2 进程和线程的概念 1.2.1 进程与线程 打开一个软件,就开启了一个进程,一个进程会包括很多个线程,线程是…...
算法--js--电话号码的字母组合
题:给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。答案可以按 任意顺序 返回。给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。 function letterCombinations (digits){if (!digits.length)…...