青少年编程与数学 02-016 Python数据结构与算法 04课题、栈与队列
青少年编程与数学 02-016 Python数据结构与算法 04课题、栈与队列
- 一、栈
- 1. 栈的定义
- 2. 栈的特点
- 3. 栈的基本操作
- 示例
- 4. 栈的实现
- (1)数组实现
- (2)链表实现
- 5. 栈的应用
- (1)函数调用
- (2)表达式求值
- (3)回溯算法
- (4)括号匹配
- (5)深度优先搜索(DFS)
- 6. 栈的优缺点
- 7. 小结
- 二、队列
- 1. 队列的定义
- 2. 队列的特点
- 3. 队列的基本操作
- 示例
- 4. 队列的实现
- (1)数组实现
- (2)链表实现
- 5. 队列的应用
- (1)任务调度
- (2)消息传递
- (3)缓冲区管理
- (4)广度优先搜索(BFS)
- (5)事件驱动编程
- 6. 队列的优缺点
- 7. 小结
- 三、双向队列(Deque)
- 1. 双向队列的定义
- 2. 双向队列的特点
- 3. 双向队列的基本操作
- 示例
- 4. 双向队列的实现
- (1)数组实现
- (2)链表实现
- 5. 双向队列的应用
- (1)滑动窗口问题
- (2)回文检查
- (3)任务调度
- (4)图的广度优先搜索(BFS)
- 6. 双向队列的优缺点
- 7. 小结
- 总结
课题摘要:
栈(Stack)是一种线性数据结构,它遵循后进先出(Last In First Out,LIFO)的原则。这意味着最后添加到栈中的元素将是第一个被移除的元素。栈在计算机科学中有着广泛的应用,例如在函数调用、表达式求值和回溯算法中。
队列(Queue)是一种线性数据结构,它遵循先进先出(First In First Out,FIFO)的原则。这意味着最早添加到队列中的元素将是第一个被移除的元素。队列在计算机科学中有着广泛的应用,例如在任务调度、消息传递和缓冲区管理中。
关键词:栈、队列
一、栈
栈(Stack)是一种线性数据结构,它遵循后进先出(Last In First Out,LIFO)的原则。这意味着最后添加到栈中的元素将是第一个被移除的元素。栈在计算机科学中有着广泛的应用,例如在函数调用、表达式求值和回溯算法中。以下是对栈的详细解释:
1. 栈的定义
栈是一种线性数据结构,它只允许在一端(称为栈顶)进行插入和删除操作。栈顶是栈中最后一个被添加的元素的位置。栈的另一端称为栈底,通常是固定的。
2. 栈的特点
- 后进先出(LIFO):最后添加的元素最先被移除。
- 栈顶操作:所有操作(插入和删除)都在栈顶进行。
- 动态大小:栈的大小可以动态变化,但通常有一个最大容量限制。
- 线性结构:栈中的元素是线性排列的,每个元素都有一个直接的前驱和后继。
3. 栈的基本操作
栈的主要操作包括:
push
:将一个元素添加到栈顶。pop
:从栈顶移除一个元素。peek
或top
:查看栈顶元素,但不移除它。is_empty
:检查栈是否为空。size
:返回栈中元素的数量。
示例
假设我们有一个栈,初始为空:
[]
执行以下操作:
push(1)
:[1]
push(2)
:[1, 2]
push(3)
:[1, 2, 3]
pop()
:[1, 2]
peek()
:返回 2
is_empty()
:返回 False
size()
:返回 2
4. 栈的实现
栈可以用数组或链表来实现。以下是两种实现方式的详细说明:
(1)数组实现
使用数组实现栈时,栈的大小通常是固定的,但可以通过动态数组(如 Python 的列表)来实现动态大小。
class Stack:def __init__(self):self.items = []def push(self, item):self.items.append(item)def pop(self):if not self.is_empty():return self.items.pop()raise IndexError("pop from empty stack")def peek(self):if not self.is_empty():return self.items[-1]raise IndexError("peek from empty stack")def is_empty(self):return len(self.items) == 0def size(self):return len(self.items)
(2)链表实现
使用链表实现栈时,栈的大小可以动态变化,但需要管理节点的分配和释放。
class Node:def __init__(self, data):self.data = dataself.next = Noneclass Stack:def __init__(self):self.top = Nonedef push(self, data):new_node = Node(data)new_node.next = self.topself.top = new_nodedef pop(self):if self.is_empty():raise IndexError("pop from empty stack")data = self.top.dataself.top = self.top.nextreturn datadef peek(self):if self.is_empty():raise IndexError("peek from empty stack")return self.top.datadef is_empty(self):return self.top is Nonedef size(self):count = 0current = self.topwhile current:count += 1current = current.nextreturn count
5. 栈的应用
栈在计算机科学中有着广泛的应用,以下是一些常见的应用场景:
(1)函数调用
在编程语言中,函数调用通常使用栈来实现。每次调用一个函数时,都会在栈上创建一个栈帧(Frame),用于存储函数的局部变量和返回地址。当函数返回时,栈帧被移除。
(2)表达式求值
栈可以用于求值表达式,特别是处理括号匹配和操作符优先级。例如,使用两个栈(一个用于操作数,一个用于操作符)可以实现中缀表达式的求值。
(3)回溯算法
栈可以用于实现回溯算法,例如在迷宫问题中,栈可以记录路径,当遇到死路时,可以回溯到上一个节点。
(4)括号匹配
栈可以用于检查括号是否匹配。例如,对于字符串 "{[()]}"
,可以使用栈来检查括号是否正确匹配。
(5)深度优先搜索(DFS)
栈可以用于实现深度优先搜索,通过栈来记录访问的节点。
6. 栈的优缺点
-
优点:
- 简单高效:栈的操作(
push
、pop
、peek
)时间复杂度为O(1)。 - 适用广泛:栈在许多算法和数据处理中都非常有用。
- 简单高效:栈的操作(
-
缺点:
- 容量限制:如果使用固定大小的数组实现栈,可能会遇到栈溢出的问题。
- 功能有限:栈只能在一端进行操作,不支持随机访问。
7. 小结
栈是一种线性数据结构,遵循后进先出(LIFO)的原则。它可以通过数组或链表实现,支持高效的操作(如 push
、pop
和 peek
)。栈在函数调用、表达式求值、括号匹配和回溯算法中有着广泛的应用。理解栈的特性和操作方法,有助于更好地使用它来解决各种编程问题。
二、队列
队列(Queue)是一种线性数据结构,它遵循先进先出(First In First Out,FIFO)的原则。这意味着最早添加到队列中的元素将是第一个被移除的元素。队列在计算机科学中有着广泛的应用,例如在任务调度、消息传递和缓冲区管理中。以下是对队列的详细解释:
1. 队列的定义
队列是一种线性数据结构,它只允许在一端(称为队尾)进行插入操作,在另一端(称为队头)进行删除操作。队头是队列中最早添加的元素的位置,队尾是队列中最后添加的元素的位置。
2. 队列的特点
- 先进先出(FIFO):最早添加的元素最先被移除。
- 队头操作:删除操作(
dequeue
)在队头进行。 - 队尾操作:插入操作(
enqueue
)在队尾进行。 - 动态大小:队列的大小可以动态变化,但通常有一个最大容量限制。
- 线性结构:队列中的元素是线性排列的,每个元素都有一个直接的前驱和后继。
3. 队列的基本操作
队列的主要操作包括:
enqueue
:将一个元素添加到队尾。dequeue
:从队头移除一个元素。peek
或front
:查看队头元素,但不移除它。is_empty
:检查队列是否为空。size
:返回队列中元素的数量。
示例
假设我们有一个队列,初始为空:
[]
执行以下操作:
enqueue(1)
:[1]
enqueue(2)
:[1, 2]
enqueue(3)
:[1, 2, 3]
dequeue()
:[2, 3]
peek()
:返回 2
is_empty()
:返回 False
size()
:返回 2
4. 队列的实现
队列可以用数组或链表来实现。以下是两种实现方式的详细说明:
(1)数组实现
使用数组实现队列时,队列的大小通常是固定的,但可以通过动态数组(如 Python 的列表)来实现动态大小。数组实现的队列需要处理数组的头部删除操作,这可能会导致效率问题。
class Queue:def __init__(self):self.items = []def enqueue(self, item):self.items.append(item)def dequeue(self):if not self.is_empty():return self.items.pop(0)raise IndexError("dequeue from empty queue")def peek(self):if not self.is_empty():return self.items[0]raise IndexError("peek from empty queue")def is_empty(self):return len(self.items) == 0def size(self):return len(self.items)
(2)链表实现
使用链表实现队列时,队列的大小可以动态变化,且插入和删除操作的时间复杂度为O(1)。链表实现的队列需要管理节点的分配和释放。
class Node:def __init__(self, data):self.data = dataself.next = Noneclass Queue:def __init__(self):self.front = Noneself.rear = Nonedef enqueue(self, data):new_node = Node(data)if self.rear is None:self.front = self.rear = new_nodereturnself.rear.next = new_nodeself.rear = new_nodedef dequeue(self):if self.is_empty():raise IndexError("dequeue from empty queue")temp = self.frontself.front = temp.nextif self.front is None:self.rear = Nonereturn temp.datadef peek(self):if self.is_empty():raise IndexError("peek from empty queue")return self.front.datadef is_empty(self):return self.front is Nonedef size(self):count = 0current = self.frontwhile current:count += 1current = current.nextreturn count
5. 队列的应用
队列在计算机科学中有着广泛的应用,以下是一些常见的应用场景:
(1)任务调度
在操作系统中,任务调度器使用队列来管理待处理的任务。任务按照到达的顺序排队等待处理。
(2)消息传递
在消息队列系统中,队列用于存储和传递消息。消息按照到达的顺序被处理。
(3)缓冲区管理
在 I/O 操作中,队列用于管理缓冲区。例如,打印任务可以被放入一个队列中,打印机按照队列的顺序处理这些任务。
(4)广度优先搜索(BFS)
在图算法中,队列用于实现广度优先搜索。队列存储待访问的节点,确保节点按照到达的顺序被访问。
(5)事件驱动编程
在事件驱动的编程模型中,队列用于管理事件。事件按照发生的顺序被处理。
6. 队列的优缺点
-
优点:
- 简单高效:队列的操作(
enqueue
、dequeue
、peek
)时间复杂度为O(1)。 - 适用广泛:队列在许多算法和数据处理中都非常有用。
- 简单高效:队列的操作(
-
缺点:
- 容量限制:如果使用固定大小的数组实现队列,可能会遇到队列溢出的问题。
- 功能有限:队列只能在一端插入,在另一端删除,不支持随机访问。
7. 小结
队列是一种线性数据结构,遵循先进先出(FIFO)的原则。它可以通过数组或链表实现,支持高效的操作(如 enqueue
、dequeue
和 peek
)。队列在任务调度、消息传递、缓冲区管理和广度优先搜索中有着广泛的应用。理解队列的特性和操作方法,有助于更好地使用它来解决各种编程问题。
三、双向队列(Deque)
双向队列(Double-Ended Queue,简称 Deque)是一种特殊的队列,它允许在队列的两端(队头和队尾)进行插入和删除操作。双向队列结合了栈和普通队列的特点,提供了更灵活的操作方式。以下是对双向队列的详细解释:
1. 双向队列的定义
双向队列是一种线性数据结构,允许在队列的两端进行插入和删除操作。它支持以下操作:
- 在队头插入元素(
appendleft
)。 - 在队尾插入元素(
append
)。 - 从队头删除元素(
popleft
)。 - 从队尾删除元素(
pop
)。
2. 双向队列的特点
- 灵活操作:支持在队列的两端进行插入和删除操作。
- 高效实现:所有操作的时间复杂度为O(1)。
- 动态大小:队列的大小可以动态变化,但通常有一个最大容量限制。
- 线性结构:队列中的元素是线性排列的,每个元素都有一个直接的前驱和后继。
3. 双向队列的基本操作
双向队列的主要操作包括:
append(x)
:在队尾插入一个元素x
。appendleft(x)
:在队头插入一个元素x
。pop()
:从队尾删除一个元素并返回。popleft()
:从队头删除一个元素并返回。peek()
或front()
:查看队头元素,但不移除它。peeklast()
或back()
:查看队尾元素,但不移除它。is_empty()
:检查队列是否为空。size()
:返回队列中元素的数量。
示例
假设我们有一个双向队列,初始为空:
[]
执行以下操作:
append(1)
:[1]
appendleft(2)
:[2, 1]
append(3)
:[2, 1, 3]
popleft()
:[1, 3]
pop()
:[1]
peek()
:返回 1
peeklast()
:返回 1
is_empty()
:返回 False
size()
:返回 1
4. 双向队列的实现
双向队列可以用数组或链表来实现。以下是两种实现方式的详细说明:
(1)数组实现
使用数组实现双向队列时,需要处理数组的头部删除操作,这可能会导致效率问题。但通过使用双端数组(如 Python 的 collections.deque
),可以高效地实现双向队列。
from collections import dequeclass Deque:def __init__(self):self.items = deque()def append(self, item):self.items.append(item)def appendleft(self, item):self.items.appendleft(item)def pop(self):if not self.is_empty():return self.items.pop()raise IndexError("pop from empty deque")def popleft(self):if not self.is_empty():return self.items.popleft()raise IndexError("popleft from empty deque")def peek(self):if not self.is_empty():return self.items[0]raise IndexError("peek from empty deque")def peeklast(self):if not self.is_empty():return self.items[-1]raise IndexError("peeklast from empty deque")def is_empty(self):return len(self.items) == 0def size(self):return len(self.items)
(2)链表实现
使用链表实现双向队列时,队列的大小可以动态变化,且插入和删除操作的时间复杂度为O(1)。链表实现的双向队列需要管理节点的分配和释放。
class Node:def __init__(self, data):self.data = dataself.prev = Noneself.next = Noneclass Deque:def __init__(self):self.front = Noneself.rear = Nonedef append(self, data):new_node = Node(data)if self.rear is None:self.front = self.rear = new_nodeelse:new_node.prev = self.rearself.rear.next = new_nodeself.rear = new_nodedef appendleft(self, data):new_node = Node(data)if self.front is None:self.front = self.rear = new_nodeelse:new_node.next = self.frontself.front.prev = new_nodeself.front = new_nodedef pop(self):if self.is_empty():raise IndexError("pop from empty deque")data = self.rear.dataif self.rear.prev:self.rear = self.rear.prevself.rear.next = Noneelse:self.front = self.rear = Nonereturn datadef popleft(self):if self.is_empty():raise IndexError("popleft from empty deque")data = self.front.dataif self.front.next:self.front = self.front.nextself.front.prev = Noneelse:self.front = self.rear = Nonereturn datadef peek(self):if self.is_empty():raise IndexError("peek from empty deque")return self.front.datadef peeklast(self):if self.is_empty():raise IndexError("peeklast from empty deque")return self.rear.datadef is_empty(self):return self.front is Nonedef size(self):count = 0current = self.frontwhile current:count += 1current = current.nextreturn count
5. 双向队列的应用
双向队列在计算机科学中有着广泛的应用,以下是一些常见的应用场景:
(1)滑动窗口问题
在处理滑动窗口问题时,双向队列可以高效地维护窗口内的最大值或最小值。例如,使用双向队列可以实现一个时间复杂度为O(n)的滑动窗口最大值算法。
(2)回文检查
双向队列可以用于检查字符串是否为回文。通过在队头和队尾同时进行操作,可以高效地判断字符串是否对称。
(3)任务调度
在任务调度中,双向队列可以用于管理任务的优先级。高优先级的任务可以插入到队头,低优先级的任务可以插入到队尾。
(4)图的广度优先搜索(BFS)
在图算法中,双向队列可以用于实现广度优先搜索。队列存储待访问的节点,确保节点按照到达的顺序被访问。
6. 双向队列的优缺点
-
优点:
- 灵活操作:支持在队列的两端进行插入和删除操作。
- 高效实现:所有操作的时间复杂度为O(1)。
- 适用广泛:在许多算法和数据处理中都非常有用。
-
缺点:
- 实现复杂:链表实现的双向队列需要管理节点的分配和释放。
- 功能有限:虽然比普通队列灵活,但仍然不支持随机访问。
7. 小结
双向队列是一种灵活的线性数据结构,允许在队列的两端进行插入和删除操作。它可以通过数组或链表实现,支持高效的操作(如 append
、appendleft
、pop
和 popleft
)。双向队列在滑动窗口问题、回文检查、任务调度和广度优先搜索中有着广泛的应用。理解双向队列的特性和操作方法,有助于更好地使用它来解决各种编程问题。
总结
栈、队列和双向队列这三种线性数据结构的定义、特点、操作方法及应用场景。栈遵循后进先出(LIFO)原则,支持在栈顶进行插入和删除操作,常用于函数调用、表达式求值和回溯算法等。队列遵循先进先出(FIFO)原则,支持在队尾插入和队头删除操作,适用于任务调度、消息传递和缓冲区管理等场景。双向队列结合了栈和队列的特点,允许在两端进行插入和删除操作,适用于滑动窗口问题、回文检查等复杂场景。
栈和队列操作简单高效,但功能有限;双向队列操作灵活,但实现相对复杂。通过对比和示例,读者可以更好地理解这些数据结构的特性,并根据实际需求选择合适的数据结构来优化程序设计和算法实现。
相关文章:
青少年编程与数学 02-016 Python数据结构与算法 04课题、栈与队列
青少年编程与数学 02-016 Python数据结构与算法 04课题、栈与队列 一、栈1. 栈的定义2. 栈的特点3. 栈的基本操作示例 4. 栈的实现(1)数组实现(2)链表实现 5. 栈的应用(1)函数调用(2)…...
Lucene.Net全文搜索引擎:架构解析与全流程实战指南
文章目录 引言:为什么选择Lucene.Net?一、Lucene.Net核心架构剖析1.1 模块化设计 二、Lucene.Net索引原理揭秘2.1 倒排索引:搜索的基石2.2 段(Segment)机制 三、全流程实战:从0到1构建搜索引擎3.1 环境准备…...
OpenSceneGraph 中的 LOD详解
LOD (Level of Detail,细节层次) 是3D图形中一种重要的优化技术,OpenSceneGraph 通过 osg::LOD 类提供了完整的LOD支持。 一、LOD 基本概念 1. 什么是LOD 核心思想:根据物体与相机的距离显示不同细节程度的模型 目的:减少远处物…...
程序化广告行业(64/89):AdX/SSP系统广告位设置全解析
程序化广告行业(64/89):AdX/SSP系统广告位设置全解析 大家好!我一直觉得在技术和营销不断融合的当下,程序化广告领域充满了机遇与挑战。之前和大家分享了程序化广告PDB模式的相关知识,今天想接着和大家一起…...
Pytorch中的计算图(Computational Graph)是什么
🧩 一、什么是计算图? 计算图是一种“有向无环图(DAG)”,表示变量(张量)之间的运算关系。 节点:张量或操作(如加法、乘法)边:数据流(即…...
Java 大视界 -- Java 大数据在航天遥测数据分析中的技术突破与应用(177)
💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…...
【Linux操作系统——学习笔记三】Linux环境下多级目录构建与管理的命令行实践报告
1.在用户主目录下,使用以下方法新建目录,并显示详细执行过程: (1)使用绝对路径在当前目录下创建 new_dir目录 (2)使用相对路径、在当前目录创建dir1、dir2、dir3目录 (3)…...
java.util.Collections中常用api
在Java中,java.util.Collections 是一个工具类,提供了大量静态方法用于操作或返回集合(如List、Set、Map等)。以下是常用的API分类整理: 1. 排序与顺序操作 sort(List<T> list) 对List进行自然顺序排序ÿ…...
批量将图片统一色调
from PIL import Image, ImageEnhance # 确保导入 ImageEnhance 模块 import osdef adjust_image_tone(image_path, output_path, r_weight1.0, g_weight1.0, b_weight1.0, brightness1.0):"""调整图片的色调、明暗,并进行去图处理。参数:image_pat…...
OCC Shape 操作
#pragma once #include <iostream> #include <string> #include <filesystem> #include <TopoDS_Shape.hxx> #include <string>class GeometryIO { public:// 加载几何模型:支持 .brep, .step/.stp, .iges/.igsstatic TopoDS_Shape L…...
docker的run命令 笔记250406
docker的run命令 笔记250406 Docker 的 run 命令用于创建并启动一个新的容器。它是 Docker 中最常用的命令之一,基本语法为: docker run [OPTIONS] IMAGE [COMMAND] [ARG...]常用选项(OPTIONS) 参数说明-d 或 --detach后台运行…...
批量将 HTML 转换为 Word/Txt/PDF 等其它格式
HTML是一种超文本标记语言,在进行网页编辑的时候非常常见,我们浏览的网站内容,都可以保存为 html 格式,如果想要将 html 格式的文档转为其它格式,比如 Word、PDF 或者 Txt,我们应该怎么做呢?今天…...
TPS入门DAY02 服务器篇
1.创建空白插件 2.导入在线子系统以及在线steam子系统库 MultiplayerSessions.uplugin MultiplayerSessions.Build.cs 3.创建游戏实例以及初始化会话创建流程 创建会话需要的函数,委托,委托绑定的回调,在线子系统接口绑定某一个委托的控制其…...
C高级,终端操作
核心要点整理 刷题作业 一、基础操作 命令行提示符结构 ubuntuubuntu:~$ 当前用户 | 连接符 | 计算机名 | 当前路径 | 用户权限 用户切换 su 用户名:切换用户sudo passwd 用户名:修改用户密码 常用指令 cd -:返回上一次路径ls:显…...
Lua语言的边缘计算
Lua语言的边缘计算探索 引言 随着物联网(IoT)、人工智能(AI)和大数据技术迅速发展,边缘计算作为一种分布式计算架构日益受到重视。其核心理念是将计算和数据存储资源更靠近数据源,以降低延迟、减轻网络负…...
RabbitMQ运维
RabbitMQ运维 一.集群1.简单介绍2.集群的作用 二.搭建集群1.多机多节点搭建步骤 2.单机单节点搭建步骤 3.宕机演示 三.仲裁队列1.简单介绍2.Raft协议Raft基本概念主节点选举选举过程 3.仲裁队列的使用 四.HAProxy负载均衡1.安装HAProxy2.HAProxy的使用 一.集群 1.简单介绍 Ra…...
【ESP32】ESP32物联网应用:MQTT控制与状态监测
ESP32物联网应用:MQTT控制与状态监测 引言 在物联网时代,远程监测和控制设备已经成为现实生活中常见的需求。本文将介绍如何使用ESP32微控制器配合MQTT协议,实现一个简单而强大的物联网应用:远程状态监测和设备控制。我们将以巴…...
如何保证RabbitMQ消息的可靠传输?
在这个图中,消息可能丢失的场景是1,2,3 1.在生产者将消息发送给RabbitMQ的时候,消息到底有没有正确的到达服务器呢,RabbitMQ提供了两种解决方案: a. 通过事务机制实现(比较消耗性能࿰…...
Redis高可用
主从复制 为什么要主从复制? 由于数据都是存储在一台服务器上,如果出事就完犊子了,比如: 如果服务器发生了宕机,由于数据恢复是需要点时间,那么这个期间是无法服务新的请求的;如果这台服务器…...
[项目总结] 在线OJ刷题系统项目技术应用(下)
🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏: 🧊 Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 🍕 Collection与…...
链表算法中常用操作和技巧
目 1.常用技巧 1.1.画图 1.2.添加虚拟头节点 1.3.大胆引入中间变量 1.4.快慢双指针 1.4.1判断链表是否有环 1.4.2找链表中环的入口 2.常用操作 2.1. 创建一个新节点 2.2.尾插 2.3.头插 1.常用技巧 1.1.画图 画图可以让一些抽象的文字语言更加形象生动 画图&#…...
MySQL基础 [二] - 数据库基础
目录 库的增删查改 查看数据库 创建数据库 删除数据库 修改数据库 认识系统编码(字符集和校验规则) 查看系统默认字符集以及校验规则 查看数据库支持的字符集和字符集校验规则 验证不同校验码编码的影响 校验规则对数据库的影响 数据库的备份…...
【Linux篇】基础IO - 文件描述符的引入
📌 个人主页: 孙同学_ 🔧 文章专栏:Liunx 💡 关注我,分享经验,助你少走弯路! 文章目录 一. 理解文件1.1 侠义理解1.2 广义理解1.3 文件操作的归类认知1.4 系统角度 二. 回顾C语言文件…...
13.【.NET 8 实战--孢子记账--从单体到微服务--转向微服务】--微服务基础工具与技术--Refit
在微服务架构中,不同服务之间经常需要相互调用以完成复杂业务流程,而 Refit 能让这种“跨服务调用”变得简洁又可靠。开发者只需将对外暴露的 REST 接口抽象成 C# 接口,并通过共享库或内部 NuGet 包在各服务中引用,这种契约优先的…...
C++ 并发性能优化实战:提升多线程应用的效率与稳定性
🧑 博主简介:CSDN博客专家、CSDN平台优质创作者,获得2024年博客之星荣誉证书,高级开发工程师,数学专业,拥有高级工程师证书;擅长C/C、C#等开发语言,熟悉Java常用开发技术,…...
前端性能优化的全方位方案【待进一步结合项目】
以下是前端性能优化的全方位方案,结合代码配置和最佳实践,涵盖从代码编写到部署的全流程优化: 一、代码层面优化 1. HTML结构优化 <!-- 语义化标签减少嵌套 --> <header><nav>...</nav> </header> <main&…...
(undone) 并行计算 CS149 Lecture3 (现代多核处理器2 + ISPC编程抽象)
url: https://www.bilibili.com/video/BV1du17YfE5G?spm_id_from333.788.videopod.sections&vd_source7a1a0bc74158c6993c7355c5490fc600&p3 如上堂课,超线程技术通过储存不同线程的 execution context,能够在一个线程等待 IO 的时候低成本切换…...
DiffAD:自动驾驶的统一扩散建模方法
25年3月来自新加坡公司 Carion 和北航的论文“DiffAD: A Unified Diffusion Modeling Approach for Autonomous Driving”。 端到端自动驾驶 (E2E-AD) 已迅速成为实现完全自动驾驶的一种有前途的方法。然而,现有的 E2E-AD 系统通常采用传统的多任务框架,…...
QScrollArea 内部滚动条 QSS 样式失效问题及解决方案
在使用 Qt 进行 UI 开发时,我们经常希望通过 QSS(Qt Style Sheets)自定义控件的外观,比如为 QScrollArea 的内部滚动条设置特定的样式。然而,有开发者遇到了这样的问题:在 UI 设计器中预览 QSS 显示效果正常,但程序运行时却显示为系统默认样式。经过反复测试和调试,最终…...
换脸视频FaceFusion3.1.0-附整合包
2025版最强换脸软件FaceFusion来了(附整合包)超变态的AI换脸教程 2025版最强换脸软件FaceFusion来了(附整合包)超变态的AI换脸教程 整合包地址: 「Facefusion_V3.1.0」 链接:https://pan.quark.cn/s/f71601…...
Qt 入门 1 之第一个程序 Hello World
Qt 入门1之第一个程序 Hello World 直接上操作步骤从头开始认识,打开Qt Creator,创建一个新项目,并依次执行以下操作 在Qt Creator中,一个Kits 表示一个完整的构建环境,包括编译器、Qt版本、调试器等。在上图中可以直…...
无锁队列简介与实现示例
1. 简介 无锁队列是一种数据结构,旨在在多线程环境中实现高效的并发访问,而无需使用传统的锁机制(如互斥锁)。无锁队列通过使用原子操作(如CAS,Compare-And-Swap)来确保线程安全,从…...
SpringMVC与SpringCloud的区别
SpringMVC与SpringCloud的核心区别 功能定位 • SpringMVC: 基于Spring框架的Web层开发模块,采用MVC(Model-View-Controller)模式,专注于处理HTTP请求、路由分发(如DispatcherServlet)和视图…...
STM32F103C8T6单片机开发:简单说说单片机的外部GPIO中断(标准库)
目录 前言 如何使用STM32F1系列的标准库完成外部中断的抽象 初始化我们的GPIO为输入的一个模式 初识GPIO复用,开启GPIO的复用功能时钟 GPIO_EXTILineConfig和EXTI_Init配置外部中断参数 插入一个小知识——如何正确的配置结构体? 初始化中断&#…...
Python urllib3 全面指南:从基础到实战应用
欢迎来到涛涛的频道,今天用到了urllib3,和大家分享下。 1、介绍 urllib3 urllib3 是 Python 中一个功能强大且用户友好的 HTTP 客户端库,它提供了许多标准库 urllib 所不具备的高级特性。作为 Python 生态中最受欢迎的 HTTP 库之一…...
25.5 GLM-4优化RAG实战:0.1%参数实现准确率飙升30%,成本直降90%!
使用 GLM-4 优化 RAG 程序:基于标注数据的 Adapter 训练实战 关键词:GLM-4 优化, RAG 增强, 数据标注, Adapter 训练, 检索增强生成 1. RAG 系统的核心挑战与优化方向 传统 RAG(Retrieval-Augmented Generation)系统常面临以下瓶颈: graph LR A[用户提问] --> B[检…...
OrangePi入门教程(待更新)
快速上手指南 https://www.hiascend.com/developer/techArticles/20240301-1?envFlag1 教学课程(含开发板配置和推理应用开发) https://www.hiascend.com/developer/devboard 开发推理应用 https://www.hiascend.com/developer/techArticles/20240326-1?envFlag1...
基于SpringBoot+Vue实现的二手交易市场平台功能一
一、前言介绍: 1.1 项目摘要 随着社会的发展和人们生活水平的提高,消费者购买能力的提升导致产生了大量的闲置物品,这些闲置物品具有一定的经济价值。特别是在高校环境中,学生群体作为一个具有一定消费水平的群体,每…...
TC3xx芯片的UCB介绍
文章目录 前言一、UCB的定义及其功能简介二、UCB_BMHDx_ORIG and UCB_BMHDx_COPY (x 0 - 3)2.1 BMHD(Boot Mode Head) 三、UCB_SSW四、UCB_PFLASH_ORIG and UCB_PFLASH_COPY4.1 Password4.2 UCB Confirmation 前言 缩写全称UCBUser Configuration BlockBMHDBoot Mode Headers…...
Airflow量化入门系列:第四章 A股数据处理与存储优化
Airflow量化入门系列:第四章 A股数据处理与存储优化 本教程系统性地讲解了 Apache Airflow 在 A 股量化交易中的应用,覆盖从基础安装到高级功能的完整知识体系。通过八章内容,读者将掌握 Airflow 的核心概念、任务调度、数据处理、技术指标计…...
《海空重力测量理论方法及应用》之一重力仪系统组成及工作原理(下)
2、三轴稳定平台型 稳定平台的作用是隔离测量载体角运动对重力观测量的影响,确保重力传感器的敏感轴方向始终与重向保持一致。 当前主流的海空重力仪使用的稳定平台方案主要有4种: ①双轴阻尼陀螺平台: ②)双轴惯导加捷联方位平台: ③三轴惯导平台; ④捷联惯导…...
C++模板递归结构详解和使用
示例代码 template<typename _SourceIterator, typename _DestT> struct convert_pointer {typedef typename convert_pointer<typename _SourceIterator::pointer, _DestT>::type type; };1. 模板参数 _SourceIterator 是输入的类型,通常表示迭代器类…...
(八)PMSM驱动控制学习---无感控制之滑膜观测器
在FOC矢量控制中,我们需要实时得到转子的转速和位置 ,但在考虑到成本和使用场合的情况下,往往使用无感控制,因为无位置传感器克服了传统机械式传感器的很多缺点和不足。比如,机械式传感器对环境要求比较严格࿰…...
蓝桥杯真题-分糖果-题解
链接:https://www.lanqiao.cn/problems/4124/learning/ 题目 复述:两种糖果,分别有9和16,分给7人,每个人得到的最少2,最多5,必需全部分完,几种分法? 复习-深度优先搜索 …...
推荐系统(二十二):基于MaskNet和WideDeep的商品推荐CTR模型实现
在上一篇文章《推荐系统(二十一):基于MaskNet的商品推荐CTR模型实现》中,笔者基于 MaskNet 构建了一个简单的模型。笔者所经历的工业级实践证明,将 MaskNet 和 Wide&Deep 结合应用,可以取得不错的效果&…...
辅助查询是根据查询到的文档片段再去生成新的查询问题
💡 辅助查询是怎么来的? 它是基于你当前查询(query)检索到的某个文档片段(chunk_result),再去“反推”出新的相关问题(utility queries),这些问题的作用是&a…...
Spring Cloud 框架为什么能处理高并发
Spring Cloud框架能够有效处理高并发场景,核心在于其微服务架构设计及多组件的协同作用,具体机制如下: 一、分布式架构设计支撑高扩展性 服务拆分与集群部署 Spring Cloud通过微服务拆分将单体系统解耦为独立子服务,每个服务可独…...
Pseduo LiDAR(CVPR2019)
文章目录 AbstractIntroductionRelated WorkLiDAR-based 3D object detectionStereo- and monocular-based depth estimationImage-based 3D object detection MethodDepth estimationPseudo-LiDAR generationLiDAR vs. pseudo-LiDAR3D object detectionData representation ma…...
强化学习课程:stanford_cs234 学习笔记(3)introduction to RL
文章目录 前言7 markov 实践7.1 markov 过程再叙7.2 markov 奖励过程 MRP(markov reward process)7.3 markov 价值函数与贝尔曼方程7.4 markov 决策过程MDP(markov decision process)的 状态价值函数7.4.1 状态价值函数7.4.2 状态…...
前端精度计算:Decimal.js 基本用法与详解
一、Decimal.js 简介 decimal.js 是一个用于任意精度算术运算的 JavaScript 库,它可以完美解决浮点数计算中的精度丢失问题。 官方API文档:Decimal.js 特性: 任意精度计算:支持大数、小数的高精度运算。 链式调用:…...