【17】数据结构之图的遍历篇章
目录标题
- 图的遍历
- 深度优先遍历 Depth First Search
- 广度优先遍历 Breadth First Search
图的遍历
从图中某一个顶点出发,沿着一些边访遍图中所有的顶点,且使用每个顶点仅被访问一次,这个过程称为图的遍历.Graph Traversal.
- 其中,访问限制标志visited[n],只取0和1值.
- 遍历算法:
- 访问初始顶点,
- 按照某种策略依次访问连通子图中未被访问的顶点,
- 寻找下一个未被访问的顶点,将此顶点作为初始顶点,转上一步骤,
- 重复上述步骤直到所有顶点均被访问为止.
深度优先遍历 Depth First Search
树先序遍历的推广.
-
基本思想:
-
1-先任意选定图中一个顶点v,从顶点v开始访问:再选定v的一个没有被访问过的邻接点w,对顶点w进行深度优先遍历,直到图中与当前顶点邻接的顶点全部被访问为止.
-
2-如果仍然有顶点未被访问,则从未访问的顶点中任选一个,执行前述遍历过程.
-
总言:是尽可能深地探索分支,当遇到末端(叶子节点或无法继续前进的点)时回溯,转而探索其他未被访问的分支.
-
最好操作是这么进行的访问过程是通过栈来控制.
-
栈的进出规则:
- 访问的顶点入栈,继续寻找邻接顶点,找到入栈;
- 直到当前的顶点找不到邻接顶点,当前栈顶出栈;
- 访问当前栈顶的元素是否还存在未被访问的邻接顶点,没有就出栈;
- 有的话就访问当前栈顶元素未被访问的邻接顶点;
- 没有的话,直到栈为空,表明图的遍历完成.
- 示意图
-
代码实现
# 深度优先遍历
class Stack:"""栈数据结构实现"""def __init__(self):self.items = []def is_empty(self):"""判断栈是否为空"""return len(self.items) == 0def push(self, item):"""元素入栈"""self.items.append(item)def pop(self):"""元素出栈并返回"""if not self.is_empty():return self.items.pop()return Nonedef peek(self):"""查看栈顶元素"""if not self.is_empty():return self.items[-1]return Noneclass Vertex:"""顶点类"""def __init__(self, data):self.data = data # 顶点数据self.first_edge = None # 指向第一条邻接边class Edge:"""边类"""def __init__(self, adj_vex):self.adj_vex = adj_vex # 邻接顶点索引self.next_edge = None # 指向下一条边class LinkedGraph:"""邻接表图结构"""def __init__(self, vertexs, edges):self.vertex_num = len(vertexs)self.edge_num = len(edges)self.vertex_list = [None] * self.vertex_num # 顶点列表# 初始化顶点和边self.add_vertex(vertexs)self.add_edge(edges)def add_vertex(self, vertexs):"""添加顶点集合"""for i in range(self.vertex_num):self.vertex_list[i] = Vertex(vertexs[i])def add_edge(self, edges):"""添加无向边集合"""for edge in edges:# 获取顶点在列表中的索引v1_idx = self.get_vertex_index(edge[0])v2_idx = self.get_vertex_index(edge[1])if v1_idx == -1 or v2_idx == -1:raise ValueError("顶点不存在")# 为两个顶点添加边(无向图双向添加)self._add_single_edge(v1_idx, v2_idx)self._add_single_edge(v2_idx, v1_idx)def _add_single_edge(self, from_idx, to_idx):"""添加单条边到指定顶点"""new_edge = Edge(to_idx)# 头插法提高效率if self.vertex_list[from_idx].first_edge is None:self.vertex_list[from_idx].first_edge = new_edgeelse:new_edge.next_edge = self.vertex_list[from_idx].first_edgeself.vertex_list[from_idx].first_edge = new_edgedef get_vertex_index(self, data):"""根据顶点值查找索引"""for i in range(self.vertex_num):if self.vertex_list[i].data == data:return ireturn -1class DepthFirstSearch:"""深度优先遍历实现"""def __init__(self, graph):self.graph = graphself.visited = [False] * graph.vertex_num # 访问标记数组self._dfs_all() # 执行遍历def _dfs_all(self):"""遍历所有连通分量"""for i in range(self.graph.vertex_num):if not self.visited[i]:self._dfs_iterative(i)def _dfs_iterative(self, start_idx):"""迭代式DFS实现"""stack = Stack()# 访问起始顶点self.visited[start_idx] = Trueprint(self.graph.vertex_list[start_idx].data, end=" ")stack.push(start_idx)while not stack.is_empty():# 获取当前顶点未访问的邻接点current_idx = stack.peek()edge = self.graph.vertex_list[current_idx].first_edgefound = Falsewhile edge:adj_idx = edge.adj_vexif not self.visited[adj_idx]:# 访问并标记邻接点self.visited[adj_idx] = Trueprint(self.graph.vertex_list[adj_idx].data, end=" ")stack.push(adj_idx)found = Truebreakedge = edge.next_edge# 没有未访问邻接点时回溯if not found:stack.pop()# ---------------------- 测试用例 ----------------------
if __name__ == "__main__":# 测试数据(无向图)vertexs = [1, 2, 3, 4, 5, 6]edges = [[1, 2], [2, 3], [3, 4], [4, 5],[2, 4], [1, 5], [2, 5], [5, 6]]# 创建图对象graph = LinkedGraph(vertexs, edges)# 执行深度优先遍历print("DFS遍历结果:", end=" ")dfs = DepthFirstSearch(graph)# 正确输出应为:1 2 3 4 5 6 或类似连通路径1 5 6 2 4 3
广度优先遍历 Breadth First Search
-
核心思想:任意选定一个顶点v开始本次访问,在访问过v后依次访问v的待访问邻接点,并将已访问的顶点放入队列 Q中,按照Q中顶点的次序,依次访问这些已被访问过的顶点的邻接点,如果队首的顶点不存在待访问邻接点,让队首顶点出队,访问新队首的待访问邻接点,如此进行下去直至队列为空。
-
主要就是对当前顶点的所有邻接点进行访问,然后下一个,再访问其所有的邻接点,一直重复。
-
直到所有顶点均被访问过。
-
示意图
-
代码实现
# 广度优先遍历
from collections import deque # 使用高效双端队列class Vertex:"""顶点类"""def __init__(self, data):self.data = data # 顶点数据self.first_edge = None # 指向第一条邻接边class Edge:"""边类"""def __init__(self, adj_vex):self.adj_vex = adj_vex # 邻接顶点索引self.next_edge = None # 指向下一条边class LinkedGraph:"""邻接表图结构"""def __init__(self, vertices, edges):self.vertex_num = len(vertices)self.edge_num = 0self.vertex_list = [None] * self.vertex_num# 初始化顶点和边self._add_vertices(vertices)self._add_edges(edges)def _add_vertices(self, vertices):"""添加顶点集合"""for i in range(self.vertex_num):self.vertex_list[i] = Vertex(vertices[i])def _add_edges(self, edges):"""添加无向边集合"""for v1, v2 in edges:idx1 = self._get_vertex_index(v1)idx2 = self._get_vertex_index(v2)if idx1 == -1 or idx2 == -1:raise ValueError("顶点不存在")# 双向添加边(无向图)self._add_single_edge(idx1, idx2)self._add_single_edge(idx2, idx1)self.edge_num += 2def _add_single_edge(self, from_idx, to_idx):"""头插法添加单条边"""new_edge = Edge(to_idx)new_edge.next_edge = self.vertex_list[from_idx].first_edgeself.vertex_list[from_idx].first_edge = new_edgedef _get_vertex_index(self, data):"""根据顶点值查找索引"""for i in range(self.vertex_num):if self.vertex_list[i].data == data:return ireturn -1class BreadthFirstSearch:"""广度优先遍历实现"""def __init__(self, graph):self.graph = graphself.visited = [False] * graph.vertex_numself._bfs_all()def _bfs_all(self):"""遍历所有连通分量"""for i in range(self.graph.vertex_num):if not self.visited[i]:self._bfs(i)def _bfs(self, start_idx):"""单连通分量BFS"""queue = deque()# 访问起始顶点self.visited[start_idx] = Trueprint(self.graph.vertex_list[start_idx].data, end=" ")queue.append(start_idx)while queue:current_idx = queue.popleft()edge = self.graph.vertex_list[current_idx].first_edgewhile edge:neighbor_idx = edge.adj_vexif not self.visited[neighbor_idx]:self.visited[neighbor_idx] = Trueprint(self.graph.vertex_list[neighbor_idx].data, end=" ")queue.append(neighbor_idx)edge = edge.next_edge# ---------------------- 测试用例 ----------------------
if __name__ == "__main__":vertices = [1, 2, 3, 4, 5, 6]edges = [(1, 2), (2, 3), (3, 4), (4, 5),(2, 4), (1, 5), (2, 5), (5, 6)]# 创建图对象graph = LinkedGraph(vertices, edges)# 执行广度优先遍历print("BFS遍历结果:", end=" ")bfs = BreadthFirstSearch(graph)
相关文章:
【17】数据结构之图的遍历篇章
目录标题 图的遍历深度优先遍历 Depth First Search广度优先遍历 Breadth First Search 图的遍历 从图中某一个顶点出发,沿着一些边访遍图中所有的顶点,且使用每个顶点仅被访问一次,这个过程称为图的遍历.Graph Traversal. 其中,…...
【gpt生成-其一】以go语言为例,详细描述一下 :语法规范BNF/EBNF形式化描述
在 Go 语言中通过 EBNF 形式化描述语法规范需要结合语言规范文档的结构,以下是详细实现方法及标准规范示例: 一、Go 语法规范结构(基于 Go 1.21 标准) ebnf 复制 // 基础元素定义 letter "A" ... "Z&quo…...
深度剖析:GPT-3.5与GPT-4的主要区别及架构解析
随着自然语言处理技术的飞速发展,OpenAI推出的各类语言模型备受瞩目。尤其是GPT-3.5和GPT-4这两个版本之间的差异,成为了技术爱好者、研究人员和企业关注的焦点。在这篇文章中,我们将探讨这两个版本的主要区别以及它们的架构特点,…...
协同推荐算法实现的智能商品推荐系统 - [基于springboot +vue]
🛍️ 智能商品推荐系统 - 基于springboot vue 🚀 项目亮点 欢迎来到未来的购物体验!我们的智能商品推荐系统就像您的私人购物顾问,它能读懂您的心思,了解您的喜好,为您精心挑选最适合的商品。想象一下&am…...
【运维学习】lvs + keepalived + 主从dns 项目搭建
需求 主机规划 环境搭建 配置主从dns 主dns 从dns 配置web服务 搭建lvs keepalived 配置master 配置backup 更改dns配置 添加VIP 配置内核参数 更改web配置 添加VIP 配置内核参数 客户端测试 需求 主机规划 主机名IP角色lvs-master192.168.239.105主lvs&#x…...
ESP32-idf学习(二)esp32C3作服务端与电脑蓝牙数据交互
一、当前需求 目前是想利用蓝牙来传输命令,或者一些数据,包括电脑、手机与板子的数据传输,板子与板子之间的数据传输。构思是一个板子是数据接收终端,在电脑或手机下发指令后,再给其他板子相应指令,也需要…...
考道路运输安全员证应具备哪些经验?
考道路运输安全员证,通常没有明确的工作经验年限要求,但具备以下相关经验会对考试有很大帮助: 驾驶经验:报考要求取得相应的机动车驾驶证 1 年以上。有实际驾驶经验,能更好地理解驾驶员的操作规范、疲劳驾驶等问题&…...
ubtuntu安装docker拉取iwebsec镜像
docker安装: --可以在这之前换源(非必要)没有权限直接加sudo sudo apt-get update sudo apt-get upgrade 安装依赖: sudo apt install apt-transport-https ca-certificates curl software-properties-common gnupg lsb-re…...
Using the CubeMX code (一)(GPIO,PWM ,Cube AI,手写数字识别 MNIST,Demo)
该例程对使用CubeMX初始化GPIO做了示范,GPIO使用HAL库进行GPIO编程分为以下几个步骤: 一、例程简述 1. 包含必要的头文件和HAL库的相关头文件 CubeMX初始化会自动包含,对手敲HAL感兴趣的同学可以熟悉下生成的代码框架学习哦~ 2. 初始化GP…...
【第46节】windows程序的其他反调试手段中篇
目录 引言 一、利用SetUnhandledExceptionFilter/Debugger Interrupts 二、Trap Flag 单步标志异常 三、利用SeDebugPrivilege 进程权限 四、利用DebugObject:NtQueryObject() 五、OllyDbg:Guard 六、Software Breakpoint Detection 引言 在程序反调试领域,存…...
【APM】How to enable Trace to Logs on Grafana?
系列文章目录 【APM】Observability Solution 【APM】Build an environment for Traces, Metrics and Logs of App by OpenTelemetry 【APM】NET Traces, Metrics and Logs to OLTP 【APM】How to enable Trace to Logs on Grafana? 前言 本文将介绍如何在Grafana上启用 …...
第十节:性能优化-如何排查组件不必要的重复渲染?
工具:React DevTools Profiler 方法:memo、shouldComponentUpdate深度对比 React 组件性能优化:排查与解决重复渲染问题指南 一、定位性能问题:React DevTools 高级用法 使用 React Developer Tools Profiler 精准定位问题组件&…...
Spring Boot 项目中发布流式接口支持实时数据向客户端推送
1、pom依赖添加 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-webflux</artifactId></dependency>2、事例代码 package com.pojo.prj.controller;import com.pojo.common.core.utils.String…...
SpringBoot整合Thymeleaf变量渲染全解析:从基础到高阶实践
Thymeleaf作为SpringBoot官方推荐的模板引擎,其核心价值在于将动态数据无缝注入静态HTML模板。本文将从基础语法到复杂场景,深入剖析Thymeleaf对各种类型变量的渲染机制。 一、环境搭建与基础配置 依赖注入 在pom.xml中引入核心依赖:<dependency><groupId>org.s…...
【verilog】Verilog 工程规范编码模板
这一套【Verilog 工程规范编码模板】,适合写清晰、可维护、可综合的 RTL 代码,适用于 FPGA/ASIC 开发: 📘 Verilog 工程级编码规范模板 1️⃣ 模块结构规范 module my_module #(parameter WIDTH 8 // 模块参数 )(input wire c…...
satoken的奇奇怪怪的错误
发了 /user/getBrowseDetail和/user/getResponDetail,但为什么进入handle里面有三次?且第一次的handle类型是AbstractHandleMapping$PreFlightHttpRequestHandlerxxx,这一次进来的时候flag为false,StpUtils.checkLogin抛出了异常 第二次进来的…...
使用prometheus-operator部署prometheus服务,并对外提供访问
先决条件: 已经部署好k8s #这里我使用的版本是1.28.12 [rootprometheus-operator /zpf/prometheus/kube-prometheus/manifests]$kubectl version Client Version: v1.28.12 Kustomize Version: v5.0.4-0.20230601165947-6ce0bf390ce3 Server Version: v1.28.12安装git服务 #安…...
FPGA阵列
FPGA(现场可编程门阵列)阵列是由多个 FPGA 芯片组成的集合,通过特定的架构和互联方式协同工作,以实现强大的计算和处理能力。以下是关于 FPGA 阵列的详细介绍: 基本原理 FPGA 是一种可重构的集成电路,内部…...
Oracle补丁安装工具opatch更新报错处理
今日,在进行Oracle补丁升级更新opatch工具包后,执行opatch命令出现了如下报错: [oracles203116 ~]$ opatch version /u01/product/oracle/12.1.0/db_1/OPatch/opatch: line 839: [: too many arguments /u01/product/oracle/12.1.0/db_1/O…...
前端笔记-html+css测试2
HTML & CSS 能力测试卷 选择题(每题2分,共20分) 下列哪个HTML5标签用于定义文档的导航链接? A) <nav> B) <navigate> C) <navbar> D) <navigation> CSS中哪个属性用于设置元素的透明度?…...
Visual Studio C++ 常用配置变量表
前言 visual studio中常用配置变量表 帮助你快速查阅,复制粘贴嘎嘎方便! 附上美图!! 一、解决方案 & 项目路径 变量含义示例(典型用法)$(SolutionDir)解决方案文件所在目录(末尾带\)$(S…...
论文阅读VACE: All-in-One Video Creation and Editing
code:https://github.com/ali-vilab/VACE 核心 单个模型同时处理多种视频生成和视频编辑任务通过VCU(视频条件单元)进行实现 方法 视频任务 所有的视频相关任务可以分为4类 文本生视频 参考图片生视频 视频生视频 视频mask生视频 VCU …...
【Python Cookbook】迭代器与生成器(一)
迭代器与生成器(一) 1.手动遍历迭代器2.代理迭代3.使用生成器创建新的迭代模式4.实现迭代器协议 1.手动遍历迭代器 你想遍历一个可迭代对象中的所有元素,但是却不想使用 for 循环。 为了手动的遍历可迭代对象,使用 next() 函数并…...
Qwen2.5-VL视觉大语言模型复现过程,没碰到什么坑
视频讲解:Qwen2.5-VL视觉大语言模型复现过程,没碰到什么坑_哔哩哔哩_bilibili Qwen2.5-VL视觉大语言模型复现过程,没碰到什么坑 今天复现下Qwen2.5-VL玩玩 https://github.com/QwenLM/Qwen2.5-VL 创建conda环境,实测22.04&#x…...
LVGL填充函数
lvgl填充函数的位置: static void disp_flush(lv_disp_drv_t * disp_drv, const lv_area_t * area, lv_color_t * color_p) {LCD_Color_Fill(area->x1,area->y1,area->x2,area->y2,(u16*)color_p);lv_disp_flush_ready(disp_drv); }填充函数的具体内容…...
关于 传感器 的详细解析,涵盖定义、分类、工作原理、常见类型、应用领域、技术挑战及未来趋势,结合实例帮助理解其核心概念
以下是关于 传感器 的详细解析,涵盖定义、分类、工作原理、常见类型、应用领域、技术挑战及未来趋势,结合实例帮助理解其核心概念: 一、传感器的定义与核心功能 1. 定义 传感器(Sensor)是一种能够将物理量ÿ…...
回归,git 分支开发操作命令
核心分支说明 主分支(master/production)存放随时可部署到生产环境的稳定代码,仅接受通过测试的合并请求。 开发分支(develop)集成所有功能开发的稳定版本,日常开发的基础分支,从该分支创建特性…...
指形铣刀的结构
指形铣刀,作为机械加工领域中一种至关重要的切削工具,其主要结构类型多样且各具特色,深入学习这些类型对于提升加工效率与精度至关重要。 首先,我们来看看最基本的直柄指形铣刀。这种铣刀的设计简洁明了,其柄部为直线…...
【verilog】always @(*) 是Verilog 中写组合逻辑
always (*) 是 Verilog 中写组合逻辑(combinational logic) 的标准写法,下面讲解含义、作用、以及为什么这么写。 🌟 什么是 always (*)? always (*) begin// 组合逻辑 end它的意思是: “只要块中用到的任…...
【IC】STA计算
这张图很好,把STA的方法展示的很清楚! 时序分析在每个设计阶段都是必不可少的,以便在现代 IC 设计中实现时序收敛。除了准确性之外,全芯片分析的效率和可扩展性也尤为重要。因此,门级静态时序分析 (STA&am…...
Linux 常用命令总结
Linux 常用命令总结(全面版) Linux 命令行是系统管理和开发的核心工具,掌握常用命令可以极大提升效率。本文全面总结 Linux 常用命令,涵盖文件操作、进程管理、网络管理、系统监控、用户管理、软件安装等多个方面,适合…...
Muduo网络库实现 [十四] - HttpResponse模块
目录 设计思路 类的设计 模块的实现 公有接口 疑问点 设计思路 这个模块和HttpRequest一样,主要就是存储http响应的要素,但是其实真正需要设置存储的要素会比http请求少,首先,要存储http的版本号,我们最终使用的是…...
2025年CNG 汽车加气站操作工考试真题练习
CNG 汽车加气站操作工考试真题练习: 一、单选题 1、CNG 加气站的核心设备是( )。 A. 压缩机 B. 储气瓶组 C. 加气机 D. 脱水装置 答案:A 解析:压缩机是 CNG 加气站的核心设备,其作用是将天然气压缩…...
B端网站建设,怎样平衡功能与美观,满足企业多元需求?
在当今数字化时代,B端网站不仅是企业展示自身形象和产品的重要窗口,更是实现业务转化和客户关系维护的关键平台。然而,B端网站建设面临着功能需求复杂与美观设计之间的平衡问题。如何在满足企业多元需求的同时,打造一个既实用又美…...
PTA:模拟EXCEL排序
Excel可以对一组纪录按任意指定列排序。现请编写程序实现类似功能。 输入格式: 输入的第一行包含两个正整数 n (≤105) 和 c,其中 n 是纪录的条数,c 是指定排序的列号。之后有 n 行,每行包含一条学生纪录。每条学生纪录由学号(6…...
Edge浏览器安卓版流畅度与广告拦截功能评测【不卡还净】
安卓设备上使用浏览器的体验,很大程度取决于两个方面。一个是滑动和页面切换时的反应速度,另一个是广告干扰的多少。Edge浏览器的安卓版本在这两方面的表现比较稳定,适合日常使用和内容浏览。 先看流畅度。Edge在中端和高端机型上启动速度快&…...
Qt 核心库总结
Qt 核心库(QtCore) QtCore 是 Qt 框架的基础模块,提供非图形界面的核心功能,是所有 Qt 应用程序的基石。它包含事件循环、信号与槽、线程管理、文件操作、字符串处理等功能,适用于 GUI 和非 GUI 应用程序。本文将从入…...
四大wordpress模板站
WP汉主题 WP汉主题是一个专注于提供高质量WordPress中文主题的平台。它为中文用户提供了丰富的WordPress主题选择,包括但不限于企业网站模板、外贸建站模板等。WP汉主题致力于帮助用户轻松搭建专业的中文网站,无论是企业官网还是个人博客,都…...
Linux之 grep、find、ls、wc 命令
Linux之 grep、find、ls、wc 命令 “ 在 Linux 世界中,命令行是不可或缺的一部分,而掌握一些常用的命令可以帮助你更有效率地管理文件和系统。本文将为你介绍四個基礎而强大的 Linux 命令:grep、find、ls 和 wc,带你开启高效文件…...
SFC的含义
SFC 即 Single File Component,也就是单文件组件,在现代前端开发尤其是 Vue.js 框架中被广泛应用。下面将从概念、结构、优势、工作原理和应用场景几个方面详细介绍 SFC。 概念 单文件组件是一种将一个组件的模板(HTML)、逻辑&a…...
Qt 性能优化总结
Qt 性能优化总结 本文简单解析 Qt 应用程序的性能优化策略,涵盖 GUI 渲染、内存管理、信号与槽、QML 性能等核心领域,并通过具体示例展示优化效果。 1. Qt 性能优化简介 性能优化目标是减少资源消耗(如 CPU、内存、GPU)、提高响…...
亚马逊关键字搜索数据通过 Product Advertising API 来获取
亚马逊关键字搜索数据主要通过 Product Advertising API 来获取。 以下是使用该接口进行关键字搜索的一般步骤: (测试示例) 注册开发者账号:访问亚马逊开发者中心,完成三方供应商注册并同意相关开发者协议࿰…...
现代C++的范式演进与工程实践深度解析(本文序号不知道怎么整的,有点问题)
引言:C++的复兴时代 在经历了"已死语言"的质疑后,现代C++正迎来前所未有的复兴。据2024年TIOBE指数显示,C++以8.33%的占比稳居第三,较2020年上升2.1个百分点。这种复兴并非偶然——随着C++20标准的全面落地和C++23特性的逐步实现,这门已有40年历史的语言正在系…...
第二十五天 - Web安全防护 - WAF原理与实现 - 练习:请求过滤中间件
一、Celery核心机制解析 1.1 分布式架构四要素 # celery_config.py BROKER_URL redis://:passwordlocalhost:6379/0 # 消息中间件 RESULT_BACKEND redis://:passwordlocalhost:6379/1 # 结果存储 TASK_SERIALIZER json ACCEPT_CONTENT [json] TIMEZONE Asia/Shanghai核…...
springboot自定义starter(避坑教学)
在实际开发中,经常会定义一些公共组件,提供给各个项目团队使用。而在springboot的项目中,一般会将这些公共组件封装为springboot的starter。 1.命名规范 Spring官方Starter通常命名为 spring-boot-starter-{name} 如:spr…...
Python 实现日志备份守护进程
实训背景 假设你是一名运维工程师,需要为公司的监控系统开发一个简单的日志备份守护进程。该进程需满足以下需求: 后台运行:脱离终端,长期监控指定目录(如 /var/log/app/)中的日志文件。自动备份…...
详解JVM的底层原理
目录 1.JVM的内存区域划分 1)程序计数器(Program Counter Register) 2)元数据区(Metaspace) 3)虚拟机栈(Java Virtual Machine Stacks) 4)堆(…...
制表符是什么?与.txt文件的关系?
李升伟 整理 制表符(Tab)是一种控制字符(ASCII码为9,Unicode为\u0009),用于在文本中创建水平间距。它的作用类似于键盘上的 Tab 键,通常表现为光标跳转到下一个预设的“制表位”(一…...
【专题刷题】双指针(三):两数之和,三数之和,四数之和
📝前言说明: 本专栏主要记录本人的基础算法学习以及LeetCode刷题记录,按专题划分每题主要记录:(1)本人解法 本人屎山代码;(2)优质解法 优质代码;ÿ…...
Java八种常见的设计模式
一、单例模式 单例模式是(Singleton Pattern)Java中最常用的设计模式之一,它保证一个类仅有一个实例,并提供一个全局访问点。 实现单例模式的核心是将类的构造方法私有化,以防止外部直接通过构造函数创建实例。同时&am…...