栈与队列:两种经典线性数据结构的深度解析
一、栈:LIFO 特性的完美诠释
(一)核心概念与抽象模型
-
定义与特性
栈是一种严格遵循后进先出(LIFO)原则的线性数据结构,其操作被限制在栈顶(Top)进行。形象化理解:如同堆叠的餐盘,最后放置的餐盘最先被取用。- 压栈(Push):数据从栈顶插入,时间复杂度 O (1)
- 出栈(Pop):数据从栈顶删除,时间复杂度 O (1)
- 典型场景:函数调用栈(保存调用上下文)、表达式求值(处理运算符优先级)、历史记录回退(如浏览器的 “后退” 功能)。
-
逻辑模型与物理结构
栈的逻辑结构是线性表,但物理实现有两种选择:- 数组实现:利用动态数组,通过
top
指针记录栈顶位置(下标从 0 或 - 1 开始),适合频繁尾操作 - 链表实现:用单链表,头节点作为栈顶,插入 / 删除在头部进行,适合内存动态分配场景
- 数组实现:利用动态数组,通过
(二)数组实现的工程细节(C 语言)
1. 结构体定义与初始化
typedef int STDataType;
typedef struct Stack {STDataType* data; // 动态数组存储数据int top; // 栈顶下标int capacity; // 当前最大容量
} Stack;void StackInit(Stack* stack) {stack->data = (STDataType*)malloc(4 * sizeof(STDataType));if (stack->data == NULL) { perror("malloc fali");return; // 内存分配失败处理}stack->top = 0;stack->capacity = 4;
}
2. 核心操作实现
- 压栈(含扩容逻辑)
void StackPush(Stack* stack, STDataType value) {// 检查是否需要扩容if (stack->top == stack->capacity - 1) {int newCapacity = stack->capacity * 2;STDataType* newData = (STDataType*)realloc(stack->data, newCapacity * sizeof(STDataType));if (newData == NULL) {perror("realloc fail");return; // 扩容失败处理}stack->data = newData;stack->capacity = newCapacity;}stack->data[stack->top++] = value; }
- 出栈(需处理栈空异常)
void StackPop(Stack* stack) {if (StackEmpty(stack))return; // 空栈无法出栈stack->top--; // 直接调整指针,无需物理删除(懒删除) }
- 获取栈顶元素
STDataType StackTop(Stack* stack) {if (StackEmpty(stack)) return; // 空栈访问异常return stack->data[stack->top]; }
3. 复杂度分析
- 压栈 / 出栈:均摊 O (1)(扩容时单次 O (n),但均摊后为常数)
- 空间复杂度:O (n)(存储 n 个元素)
(三)典型应用:有效的括号
问题:判断字符串"()[]{}"
是否括号匹配
算法步骤:
- 遍历字符串,遇左括号
({[
则压栈 - 遇右括号
) ] }
则检查栈顶是否为对应左括号: 匹配则出栈,不匹配则直接返回 false - 遍历结束后,栈空则合法,否则剩余左括号未匹配
代码关键点:用字典(或 switch)建立左右括号映射关系,处理边界情况(如字符串长度为奇数直接非法)。
二、队列:FIFO 特性的典型代表
(一)核心概念与抽象模型
-
定义与特性
队列是遵循先进先出(FIFO)原则的线性结构,插入操作在队尾(Rear),删除操作在队头(Front)。形象化理解:如同排队购票,先排队的人先接受服务。- 入队(Enqueue):数据从队尾插入,时间复杂度 O (1)
- 出队(Dequeue):数据从队头删除,时间复杂度 O (1)
- 典型场景:操作系统进程调度(如就绪队列)、网络请求缓冲、BFS 算法(逐层访问图节点)。
-
逻辑模型与物理结构
- 链表实现:用双向链表或单链表,维护头指针(队头)和尾指针(队尾),适合频繁头尾操作
- 数组实现:普通数组实现需移动元素(头删除低效),故更适合循环队列实现
(二)链表实现的工程细节(C 语言)
1. 结构体定义与初始化
typedef int QDataType;
// 队列节点
typedef struct QueueNode {QDataType value;struct QueueNode* next;
} QueueNode;// 队列整体结构
typedef struct Queue {QueueNode* front; // 队头指针(指向第一个节点)QueueNode* rear; // 队尾指针(指向最后一个节点)int size; // 元素个数(优化:避免遍历计算长度)
} Queue;void QueueInit(Queue* queue) {queue->front = queue->rear = NULL;queue->size = 0;
}
2. 核心操作实现
- 入队(处理空队列场景)
void QueuePush(Queue* queue, QDataType value) {QueueNode* newNode = (QueueNode*)malloc(sizeof(QueueNode));if (newNode == NULL){peeror("malloc fail");return;}newNode->value = value;newNode->next = NULL;if (QueueEmpty(queue)) { // 空队列时头尾指针指向同一节点queue->front = queue->rear = newNode;} else { // 非空时尾指针的next指向新节点,尾指针后移queue->rear->next = newNode;queue->rear = newNode;}queue->size++; }
- 出队(处理单节点队列)
void QueuePop(Queue* queue) {if (QueueEmpty(queue)) return;QueueNode* temp = queue->front;queue->front = queue->front->next; // 头指针后移free(temp); // 释放内存if (queue->front == NULL) { // 若删除后队列为空,尾指针置空queue->rear = NULL;}queue->size--; }
- 获取队头 / 队尾元素
QDataType QueueFront(Queue* queue) {if (QueueEmpty(queue))return;return queue->front->value; } QDataType QueueBack(Queue* queue) {if (QueueEmpty(queue)) return;return queue->rear->value; }
(三)特殊实现:设计循环队列
1. 设计目标
避免普通数组队列 “假溢出” 问题(队尾到达数组末尾但头部有空闲空间),通过环形结构复用空间。
2. 关键参数与状态判断
typedef struct {int* data; // 存储数组int front; // 队头下标(指向实际队头元素)int rear; // 队尾下标(指向队尾元素的下一个空位)int capacity; // 数组容量(含一个预留空位)
} MyCircularQueue;
- 队空条件:
front == rear
- 队满条件:
(rear + 1) % capacity == front
- 元素个数:
(rear - front + capacity) % capacity
3. 核心操作实现(入队为例)
bool MyCircularQueueEnQueue(MyCircularQueue* obj, int value) {if (MyCircularQueueIsFull(obj)) return false;obj->data[obj->rear] = value; // 先赋值obj->rear = (obj->rear + 1) % obj->capacity; // 再移动指针return true;
}
三、深度对比:栈 vs 队列的本质差异
维度 | 栈(Stack) | 队列(Queue) |
---|---|---|
数据访问原则 | 后进先出(LIFO) | 先进先出(FIFO) |
操作限制 | 仅栈顶可插入 / 删除 | 队尾插入、队头删除 |
典型底层实现 | 数组(动态扩容,尾操作高效) | 链表(头尾指针,头删除高效) |
空间特性 | 栈顶指针移动,无需频繁内存分配 | 节点动态创建 / 销毁,可能有碎片 |
适用算法 | 深度优先搜索(DFS)、递归模拟 | 广度优先搜索(BFS)、层次遍历 |
内存管理 | 数组实现需处理扩容(均摊 O (1)) | 链表实现需手动释放节点内存 |
四、进阶应用:数据结构的 “跨界” 实现
1. 用队列实现栈
核心思路:维护两个队列q1
和q2
,入栈时将元素加入非空队列,出栈时将非空队列的前 n-1 个元素转移到另一个队列,最后剩余元素即为栈顶。
- 入栈操作:
push(x)
→ 加入非空队列(若均空则选q1
) - 出栈操作:
pop()
→ 将非空队列的元素依次出队并入队到另一个队列,直到剩 1 个元素,弹出该元素
2. 用栈实现队列
核心思路:两个栈inStack
和outStack
,入队时压入inStack
,出队时若outStack
为空则将inStack
全部元素倒序压入outStack
(实现 FIFO)。
- 入队操作:
push(x)
→inStack.push(x)
- 出队操作:
pop()
→ 若outStack
空,先将inStack
全部转移到outStack
,再弹出outStack
栈顶
五、工程实践中的注意事项
1. 边界条件处理
- 栈操作需检查栈空(避免越界访问)
- 队列操作需检查队空(避免空指针解引用)
- 循环队列需严格区分队空与队满条件(通过预留空位或计数器)
2. 内存管理最佳实践
- 数组实现的栈 / 队列:初始化时分配合理初始容量,扩容时使用
realloc
避免数据拷贝 - 链表实现的队列:出队时必须释放节点内存,销毁队列时需遍历释放所有节点
- 避免内存泄漏:建立 “初始化 - 使用 - 销毁” 的完整生命周期管理流程
3. 语言特性适配
- C++:可直接使用 STL 的
stack
(底层 deque)和queue
(底层 list/deque) - Python:
collections.deque
提供高效的头尾操作(替代原生 list 的pop(0)
低效操作) - Java:
java.util.Stack
(过时,推荐用Deque
实现),Queue
接口有LinkedList
等实现
六、总结:数据结构设计的本质
栈和队列的核心价值在于通过限制操作接口,实现特定的访问顺序。这种 “受限的数据访问” 思想是计算机科学的重要设计范式:
- 栈的 LIFO 特性适合处理 “嵌套”“回溯” 场景(如函数调用、语法分析)
- 队列的 FIFO 特性适合处理 “有序”“缓冲” 场景(如任务调度、数据流处理)
理解这两种结构,不仅要掌握 API 接口,更要深入底层实现(数组 vs 链表的选择、边界条件处理、内存管理),以及在算法设计中的灵活运用(如用栈模拟递归,用队列实现层序遍历)。它们是理解更复杂数据结构(如优先队列、双端队列)的基础,更是培养 “问题建模能力” 的重要切入点。
通过实际编码实现栈和队列的各个操作,处理各种边界情况,才能真正掌握其精髓 —— 这正是计算机科学 “从抽象到具体” 的工程思维体现。
附录
栈
//stack.h
#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>
// 支持动态增长的栈
typedef int STDataType;
typedef struct Stack
{STDataType* arr;int top; // 栈顶int capacity; // 容量
}Stack;
// 初始化栈
void StackInit(Stack* ps);
// 入栈
void StackPush(Stack* ps, STDataType data);
// 出栈
void StackPop(Stack* ps);
// 获取栈顶元素
STDataType StackTop(Stack* ps);
// 获取栈中有效元素个数
int StackSize(Stack* ps);
// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0
bool StackEmpty(Stack* ps);
// 销毁栈
void StackDestroy(Stack* ps);
//stack.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"Stack.h"
// 初始化栈
void StackInit(Stack* ps)
{ps->arr = NULL;ps->capacity = ps->top = 0;
}
// 入栈
void StackPush(Stack* ps, STDataType data)
{assert(ps);if (ps->capacity == ps->top){int newcapacity = ps->capacity == 0 ? 4 : 2 * ps->capacity;STDataType* tmp = (STDataType*)realloc(ps->arr, newcapacity * sizeof(STDataType));if (tmp == NULL){perror("realloc fail");exit(1);}ps->arr = tmp;ps->capacity = newcapacity;}ps->arr[ps->top++] = data;}
// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0 bool StackEmpty(Stack* ps)
{assert(ps);return ps->top == 0;
}
// 出栈
void StackPop(Stack* ps)
{assert(!StackEmpty(ps));--ps->top;
}
// 获取栈顶元素
STDataType StackTop(Stack* ps)
{assert(!StackEmpty(ps));return ps->arr[ps->top - 1];
}
// 获取栈中有效元素个数
int StackSize(Stack* ps)
{assert(!StackEmpty(ps));return ps->top;}
// 销毁栈
void StackDestroy(Stack* ps)
{if (ps->arr != NULL)free(ps->arr);ps->arr = NULL;ps->capacity = ps->top = 0;
}
队列
//Queue.h
#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>typedef int QDataType;
typedef struct QListNode
{struct QListNode* next;QDataType data;
}QNode;// 队列的结构
typedef struct Queue
{QNode* front;QNode* rear;
}Queue;// 初始化队列
void QueueInit(Queue* q);
// 队尾入队列
void QueuePush(Queue* q, QDataType data);
// 队头出队列
void QueuePop(Queue* q);
// 获取队列头部元素
QDataType QueueFront(Queue* q);
// 获取队列队尾元素
QDataType QueueBack(Queue* q);
// 获取队列中有效元素个数
int QueueSize(Queue* q);
// 检测队列是否为空,如果为空返回非零结果,如果非空返回0
bool QueueEmpty(Queue* q);
// 销毁队列
void QueueDestroy(Queue* q);
//Queue.c
#define _CRT_SECURE_NO_WARNINGS 1
#include"Queue.h"
// 初始化队列
void QueueInit(Queue* q)
{q->front = q->rear = NULL;
}
// 队尾入队列
void QueuePush(Queue* q, QDataType data)
{QNode* newnode = (QNode*)malloc(sizeof(QNode));if (newnode == NULL){perror("malloc fail1");exit(1);}newnode->data = data;newnode->next = NULL;if (q->front == NULL){q->front = q->rear = newnode;}else{q->rear->next = newnode;q->rear = newnode;}
}
// 检测队列是否为空,如果为空返回非零结果,如果非空返回0
bool QueueEmpty(Queue* q)
{assert(q);return q->front == NULL;
}
// 队头出队列
void QueuePop(Queue* q)
{assert(!QueueEmpty(q));if (q->front == q->rear){free(q->front);q->front = q->rear = NULL;}else{QNode* tmp = q->front->next;free(q->front);q->front = tmp;}
}
// 获取队列头部元素
QDataType QueueFront(Queue* q)
{assert(!QueueEmpty(q));return q->front->data;
}
// 获取队列队尾元素
QDataType QueueBack(Queue* q)
{assert(!QueueEmpty(q));return q->rear->data;}
// 获取队列中有效元素个数
int QueueSize(Queue* q)
{assert(q);int count = 0;QNode* tmp = q->front;while (tmp != NULL){count++;tmp = tmp->next;}return count;
}
// 销毁队列
void QueueDestroy(Queue* q)
{assert(q);QNode* pcur = q->front;while (q->front){QNode* tmp = q->front->next;free(q->front);q->front = tmp;}q->front = q->rear = NULL;
}
相关文章:
栈与队列:两种经典线性数据结构的深度解析
一、栈:LIFO 特性的完美诠释 (一)核心概念与抽象模型 定义与特性 栈是一种严格遵循后进先出(LIFO)原则的线性数据结构,其操作被限制在栈顶(Top)进行。形象化理解:如同堆…...
0x01、Redis 主从复制的实现原理是什么?
Redis 主从复制概述 Redis 的主从复制是一种机制,允许一个主节点(主实例)将数据复制到一个或多个从节点(从实例)。通过这一机制,从节点可以获取主节点的数据并与之保持同步。 复制流程 开始同步…...
Python实现贪吃蛇一
贪吃蛇是一款经典的小游戏,最近尝试用Python实现它。先做一个基础版本实现以下目标: 1、做一个按钮,控制游戏开始 2、按Q键退出游戏 3、右上角显示一个记分牌 4、随机生成一个食物,蛇吃到食物后长度加一,得10分 5、蛇碰…...
01-libVLC的视频播放器:环境搭建以及介绍
项目展示项目播放器 VLC简介VLC媒体播放器(VideoLAN Client)是一款开源、跨平台的自由多媒体播放器,由VideoLAN项目开发。它支持众多音频与视频格式(如MPEG-2、MPEG-4、H.264、MKV、WebM、WMV、MP3等),以及DVD、VCD和各种流媒体协议。 VLC的特点跨平台支持:Windows、mac…...
linux内核升级
这里介绍一下linux内核升级 因为需要搭建k8s集群内核内核版本过低会导致集群出现问题,为了避免问题发生我们对集群内核进行升级处理 这个是我目前本身的内核版本 用了很多的镜像站去进行更新发现更新不了(阿里云不能用了,貌似是删除了&…...
电感详解:定义、作用、分类与使用要点
一、电感的基本定义 电感(Inductor) 是由导线绕制而成的储能元件,其核心特性是阻碍电流变化,将电能转化为磁能存储。 基本公式: 自感电动势: E -L * (di/dt) (L:电感值,…...
扩散模型简介
扩散模型简介 基本原理 扩散模型是一种基于概率扩散过程的生成模型,其核心思想是通过正向扩散过程和反向去噪过程生成数据: 正向扩散过程:从真实数据(如图像)开始,逐步添加高斯噪声,最终将数据…...
MySQL安装实战分享
一、在 Windows 上安装 MySQL 1. 下载 MySQL 安装包 访问 MySQL 官方下载页面。选择适合你操作系统的版本。一般推荐下载 MySQL Installer。 2. 运行安装程序 双击下载的安装文件(例如 mysql-installer-community-<version>.msi)。如果出现安全…...
掌握 Git 的十大基础命令
李升伟 编译 在 IT 领域,很少有技术能像 Git 一样占据绝对主导地位,几乎无人能及。Git 在软件开发中扮演着核心角色,其影响力之大甚至让其他版本控制系统(如 SVN 和 Mercurial)几乎被淘汰。如今,我们已难以…...
58-使用wordpress快速创建个人网站
直接找台可以联网的linux(我的环境是rocky8.9)一顿运行,思路就是安装docker,然后启动一个数据库,然后启动一个wordpress,然后就是把端口暴露出来。 227 yum remove podman 228 yum install -y yum-utils…...
若依前后端分离版运行教程、打包教程、部署教程
后端打包教程 注意:需要先运行redis 2、前端运行教程 2.1安装依赖 2.2运行 打开浏览器查看,地址:http://localhost:80 3、前端打包教程 3.1打包 3.2运行打包好的文件,先找到打包好的文件 这是nginx的文件结构 将打包好的文件放到html目录下…...
【Python3教程】Python3基础篇之数据结构
博主介绍:✌全网粉丝22W+,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物联网、机器学习等设计与开发。 感兴趣的可…...
transformers的 pipeline是什么:将模型加载、数据预处理、推理等步骤进行了封装
transformers的 pipeline是什么:将模型加载、数据预处理、推理等步骤进行了封装 pipe = pipeline("text-generation", model=model, tokenizer=tokenizer, max_new_tokens=50 )pipeline :这是 transformers 库中一个非常实用的工具函数。它可以基于预训练模型快速构…...
十七、TCP编程
TCP 编程是网络通信的核心,其 API 围绕面向连接的特性设计,涵盖服务端和客户端的交互流程。以下是基于 C 语言的 TCP 编程核心 API 及使用流程的详细解析: 核心 API 概览 函数角色描述socket()通用创建套接字,指定协议族…...
Obsidian 技巧篇
Obsidian 技巧篇 本篇文章主要汇总分享几个 Ob 中好用的小技巧,包括嵌入视频播放、文本颜色设置、插入大纲、Mermaid 绘制图形。原文见于:Obsidian技巧篇。 嵌入视频播放 <iframe width"860" height"700" src"https://ww…...
使用Fortran读取HDF5数据
使用Fortran读取HDF5数据 下面我将介绍如何在Fortran中读取HDF5文件中的各种类型数组数据,包括一维数组、二维数组、元数组和变长数组。 准备工作 首先需要确保系统安装了HDF5库,并且在编译时链接了HDF5库。例如使用gfortran编译时: gfor…...
L36.【LeetCode题解】查找总价格为目标值的两个商品(剑指offer:和为s的两个数字) (双指针思想,内含详细的优化过程)
目录 1.LeetCode题目 2.分析 方法1:暴力枚举(未优化的双指针) 方法2:双指针优化:利用有序数组的单调性 版本1代码 提问:版本1代码有可以优化的空间吗? 版本2代码 提问:版本2代码有可以优化的空间吗? 版本3代码(★推荐★) 3.牛客网题目:和为s的数字 1.LeetCode题目 …...
mysql 商城商品属性开发的动态解决方案
终极方案:动态属性解决方案 推荐使用 JSON 字段 虚拟列索引 的组合方案 结合灵活存储与查询优化,平衡扩展性与性能 完整实现步骤 步骤 1:创建基础表结构 CREATE TABLE products (id INT PRIMARY KEY AUTO_INCREMENT,name VARCHAR(100) NO…...
Java递归练习----猴子偷桃
问题: 有一堆桃子,猴子第一天吃灵其中的一般,并在多吃了一个!以后每天猴子都吃其中的一半,然后多吃一个。当到第十天时,想再吃时(即还没吃),发现只有1个桃子了ÿ…...
[干货]PHM学习软件|PHM预测性维护系统
使用步骤教程如下 1、登录 用户名:52phm 密码:xxx (区别在于不同用户密钥不一样) 2、上传需要分析的数据集 支持数据集格式:csv、xlsx、xls、mat、json 3、主题1:机械参数计算 计算轴承、齿轮、皮带的…...
详解正则表达式中的?:、?= 、 ?! 、?<=、?<!
1、?: - 非捕获组 语法: (?:pattern) 作用: 创建一个分组但不捕获匹配结果,不会将匹配的文本存储到内存中供后续使用。 优势: 提高性能和效率 不占用编号(不会影响后续捕获组的编号) 减少内存使用 // 使用捕获组 let regex1 /(hell…...
Java常见面试问题
一.Liunx 二.Java基础 1.final 2.static 3.与equals 三.Collection 1.LIst 2.Map 3.Stream 四、多线程 1.实现方法 2.线程池核心参数 3.应用场景 五、JVM 1.堆 2.栈 六、Spring 1.面向对象 2.IOC 3.AOP 七、Springboot 1.自动装配 八、SpringCloud 1.Nacos 2.seata 3.ga…...
C#MQTT协议服务器与客户端通讯实现(客户端包含断开重连模块)
C#MQTT协议服务器与客户端通讯实现 1 DLL版本2 服务器3 客户端 1 DLL版本 MQTTnet.DLL版本-2.7.5.0 基于比较老的项目中应用的DLL,其他更高版本变化可能较大,谨慎参考。 2 服务器 开启服务器 关闭服务器 绑定事件【客户端连接服务器事件】 绑定事件【客户…...
GGML源码逐行调试(上)
目录 前言1. 简述2. 环境配置3. ggml核心概念3.1 gguf3.2 ggml_tensor3.3 ggml_backend_buffer3.4 ggml_context3.5 backend3.6 ggml_cgraph3.7 ggml_gallocr 4. 推理流程整体梳理4.1 时间初始化与参数设置4.2 模型加载与词汇表构建4.3 计算图与内存分配4.4 文本预处理与推理过…...
智能测试用例生成:老旧平台页面查询功能的大模型改造
引言 由于GUI小工具【Deepseek APIPython 测试用例一键生成与导出】的不断升级实践,发现大模型的需求文档解析生成测试用例的可直接复用率不太理想,因此萌生了对老旧系统升级改造的想法。旧测试用例生成平台主要在于采集用户输入的字段名称、字段类型及…...
使用Python解决Logistic方程
引言 在数学和计算机科学中,Logistic 方程是描述人口增长、传播过程等现象的一种常见模型。它通常用于表示一种有限资源下的增长过程,比如动物种群、疾病传播等。本文将带领大家通过 Python 实现 Logistic 方程的求解,帮助你更好地理解这一经典数学模型。 1.什么是 Logist…...
文件上传基本原理靶场实现
一. 漏洞原理 未经验证的上传机制: 应用程序未对用户上传的文件进行充分验证,包括: 文件类型/扩展名:仅依赖客户端提交的MIME类型或简单检查扩展名(如.jpg),但未验证文件实际内容。 文件内容&a…...
灰色预测模型:GM(1,1)预测模型
灰色预测模型 灰色预测的主要特点是模型使用的不是原始数据序列,而是生成的数据序列。核心体系是灰色模型,即对原始数据作累加生成(或其他方法生成)得到近似的指数规律再进行建模的方法,优点是不需要很多的数据&#…...
SPORT(Serial Port)接口
SPORT(Serial Port)接口是DSP芯片中常用的高速同步串行通信接口,主要用于与外部设备(如ADC、DAC、编解码器等)进行数据传输。以下是对SPORT接口的详细介绍: 1. SPORT接口概述 SPORT接口设计用于高效传输连…...
Python及C++中的字典
一、Python中的字典 (一)基本概念 字典(dict)是Python中一种可变容器模型,用于存储键值对(key:value)。字典的键必须是不可变类型(如字符串、数字或元组),而…...
Neo4j GDS-11-neo4j GDS 库中相似度算法实现
neo4j GDS 系列 Neo4j APOC-01-图数据库 apoc 插件介绍 Neo4j GDS-01-graph-data-science 图数据科学插件库概览 Neo4j GDS-02-graph-data-science 插件库安装实战笔记 Neo4j GDS-03-graph-data-science 简单聊一聊图数据科学插件库 Neo4j GDS-04-图的中心性分析介绍 Neo…...
网络互连与互联网2
1.IP数据报首部在IHL 字段的最小值为5 2.三层交换机包括二层交换和三层转发,二层交换由硬件实现,三层转发采用软件实现 3.在BGP路由选择协议中,AS_PATH属性可以避免在AS之间产生环路 4.常用的电子邮件协议:SMTP(25&…...
4月12日随笔
今天大风天气的第一天,周六,早上九点半起来听了排球技术台培训。结果一天都没顾得上看教学视频。黄老师说有排球基础的可以试试当主裁,那一定要争取一下! 上午看了两集小排球,然后开始了解一些中介相关信息。因为下午…...
web自动化测试
自动化测试理论 UI:User Interface(用户接口-用户界面),主要包括:app、web ui自动化测试:使用工具或代码执行用例的过程 什么样的项目适合做自动化 1、需要回归测试项目(甲方自营项目、金…...
代码随想录二叉树小结1;(递归与迭代法小结)
一、递归遍历 1.递归算法三要素: 确定递归函数的参数和返回值: 在递归函数里加上递归的过程中需要处理的参数, 然后明确每次递归的返回值是什么,最后确定递归函数的返回类型。 确定终止条件: 递归算法运行的时候&…...
Audacity命令:“播录”菜单相关命令
1 Audacity命令:“播录”菜单相关命令 1.1 播录菜单 播录菜单中的命令可让您播放、停止、循环播放、擦洗音频或录制音频(包括定时录制和声控录制)。 Scripting IdActionParameters描述RescanDevice:Rescan Audio Devicesnone重新扫描连接到…...
Python及C++中的集合
1. Python 中的集合(set) 1.1 特性 无序性:集合中的元素没有顺序,不能通过索引访问。唯一性:集合中的元素不能重复,如果尝试添加重复的元素,集合会自动忽略。可变性:集合是可变的&…...
[CF2086E] Zebra-like Numbers 题解
确简单的啊,可是自己就是想不到。 考虑计算一个数的斑马值。贪心地,尽量选大的斑马数减即可。 考虑 DP,设 d p i , j dp_{i, j} dpi,j 表示 [ 1 , i ] [1, i] [1,i] 中斑马值为 j j j 的数的个数。那么显然有 d p i , j d p i − m …...
Linux-内核驱动
open uboot.bin target-connect U-Boot(Universal Boot Loader)是一种广泛使用的开源引导加载程序,它允许用户从各种设备(如硬盘、USB设备、网络等)加载操作系统。U-Boot提供了丰富的命令行接口(CLI&#…...
[Dify] 使用 Docker 本地部署 Dify 并集成 Ollama 模型的详细指南
在 AI 应用快速发展的今天,开源项目如 Dify 正成为构建本地化 AI 应用的利器。通过 Dify,你可以轻松地集成不同的大语言模型(LLM),如 Ollama,并快速创建可交互的 AI 应用。本篇文章将带你一步步通过 Docker…...
ESP32+Arduino入门(三):连接WIFI获取当前时间
ESP32内置了WIFI模块连接WIFI非常简单方便。 代码如下: #include <WiFi.h>const char* ssid "WIFI名称"; const char* password "WIFI密码";void setup() {Serial.begin(115200);WiFi.begin(ssid,password);while(WiFi.status() ! WL…...
软件架构评估两大法:ATAM 和 SAAM 的对比与实践
架构权衡分析方法(ATAM)和软件架构分析方法(SAAM)是软件架构评估领域中非常重要的两种方法,以下为你详细介绍: 一、架构权衡分析方法(ATAM) 1.背景与起源:ATAM 是由卡耐…...
《AI大模型应知应会100篇》第13篇:大模型评测标准:如何判断一个模型的优劣
第13篇:大模型评测标准:如何判断一个模型的优劣 摘要 近年来,大语言模型(LLMs)在自然语言处理、代码生成、多模态任务等领域取得了显著进展。然而,随着模型数量和规模的增长,如何科学评估这些模…...
编译 OpenCV 时,cmake 找到 TBB 的方法
编译 OpenCV 时,cmake 找到 TBB 的方法 编译 OpenCV 时,cmake 找到 TBB 的方法 编译 OpenCV 时,cmake 找到 TBB 的方法 HKEY_LOCAL_MACHINE\SOFTWARE\Intel\oneAPI\TBB\2022.1.0cmake 是从上面的注册表里找到的 TBB 安装路径。 这个键下面有…...
SMT贴片组装工艺优化与高效生产
内容概要 现代SMT贴片组装工艺的优化与高效生产涉及多维度技术协同,其核心在于构建精密可控的制造体系。本文系统梳理了从焊接参数调控到智能检测部署的全链路关键环节,重点解析影响生产效能的核心变量及其相互作用机制。通过对比不同贴装设备的速度-精…...
leetcode刷题日记——有效的数独
[ 题目描述 ]: [ 思路 ]: 题目要求求一个数独题目是否有效,即每行,每列,每个九宫格都不能出现相同的数字暴力求解:对每行,每列,以及九宫格进行检查是否存在相同数字运行如下 boo…...
Agent2Agent协议学习资源大全:从理论到实践
下面整理了一份关于谷歌 A2A 协议的学习资源,分为官方资源、开发教程/实践、行业解读和视频教程四个部分,方便您系统性地学习和掌握相关知识: 1. 官方资源 A2A 协议 GitHub 仓库 官方开源代码库,包含协议规范、示例代码和详细文档…...
PCDN收益高低的关键因素
PCDN(P2P内容分发网络)收益好的三个主要关键因素是:硬件配置与性能、网络环境与质量、业务调度与策略。 1. 硬件配置与性能 设备稳定性与兼容性 PCDN节点需长时间稳定运行,硬件性能直接影响收益。例如,使用高性能CPU、…...
ckeditor4.22版本 ckfinder php8版本下,上传提示400的问题
ckeditor4.22版本,ckfinder3,CKFinder 3 for PHP版本。 图片上传时提示:400错误,bad request。 通过编辑文件 D:\wamp\www\module\ckfinder\config.php 修改其配置: ini_set(display_errors, 1); $config[debug] tru…...
2025第四届大学生算法挑战赛 赛前测试赛 题解
前言 题解 测试考场【算法编程赛道】2025第四届大学生算法挑战赛 继续用Deepseek进行求解,还是非常丝滑。 A. 追债之旅 思路: 图论 bfs题 利用deepseek,直接给出答案 感觉deepseek在输入输出上,显得有些啰嗦。 # codingutf-8 import he…...