数据结构——停车场管理问题
目录
- 1、问题描述
- 2、逐步分析
- 1)涉及操作
- 2)代码实现
- 3、代码整合
1、问题描述
1、题目
设停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列(大门在最南端,最先到达的第一辆车停放在车场的最北端),若停车场已停满n辆汽车,则后来的汽车只能在门外的便道上等候,一旦有车开走,则排在便道上的第一辆车即可开入;当停车场内某辆车要离开时,在其之后开入的车辆必须先退出停车场让路,待该辆车开出大门外,其他车辆再按原次序进入停车场,每辆停放在停车场的车在其离开停车场时必须按其停留的时间长短交纳费用。试为停车场编制按上述要求进行管理的模拟程序。
2、设计要求
以栈模拟停车场,以队列模拟停车场外的便道,按照从终端读入的输入数据的方式进行模拟管理。输入1,表示车辆到达;输入2,表示车辆离开;输入3,表示显示出停车场内及便道上的停车情况;输入4,表示退出系统。车辆到达操作,需输入汽车牌照号码及到达时间;车辆离开操作,需输入汽车在停车场的位置及离开时刻,且应输出汽车在停车场内停留的时间和应缴纳的费用(在便道上停留的时间不收费)。
2、逐步分析
1)涉及操作
①基础操作
- 初始化
- 判断栈/队列为空
- 判断栈/队列为满
- 计算栈/队列长度
- 入栈/队列
- 出栈/队列
- 栈/队列打印
②要求操作
- 车辆到达
- 车辆离开
2)代码实现
1、结构体定义
①车辆信息
typedef struct Car
{int CarNo;//车牌号int CarTime;//车进入时间
}Car;
②顺序栈
typedef struct SqStack
{Car* data;//车辆信息int top;//栈顶int size;//长度
}SqStack;
③循环队列
typedef struct SqQueue
{Car* data;//车辆信息int top;//队头int tail;//队尾int size;//长度
}SqQueue;
2、基础操作
①初始化
栈:
SqStack* InitStack()
{SqStack* s = (SqStack*)malloc(sizeof(SqStack));s->data = (Car*)malloc(sizeof(Car) * MAXSIZE_St);if (s->data == NULL || s->data == NULL){return NULL;}s->size = 0;s->top = 0;//表示栈为空return s;
}
队列:
SqQueue* InitQueue()
{SqQueue* q = malloc(sizeof(SqQueue));q->data = (Car*)malloc(sizeof(Car) * MAXSIZE_Qu);if (!q || !(q->data)){return NULL;}//初始头指针和尾指针指向0索引q->top = q->tail = 0;return q;
}
②为空判断
栈:
int StackEmpty(SqStack* s)
{if (s->top == 0)return 1;//为空elsereturn 0;//不为空
}
队列:
int QueueEmpty(SqQueue* q)
{if (q->top == q->tail){return 1;//为空}return 0;//不为空
}
③为满判断
栈:
int StackFull(SqStack* s)
{if (s->size != MAXSIZE_St)return 0;//未满elsereturn 1;//已满
}
队列:
int QueueFull(SqQueue* q)
{return ((q->tail + 1) % MAXSIZE_Qu == q->top) ? 1 : 0;
}
④长度计算
栈:
int StackLength(SqStack* s)
{return s->size;
}
队列:
int QueueLength(SqQueue* q)
{return (q->tail - q->top + MAXSIZE_Qu) % MAXSIZE_Qu;
}
⑤入栈/队列
栈:
void Push(SqStack* s, int n, int t1)
{s->data[s->top].CarNo = n;s->data[s->top].CarTime = t1;s->top++;s->size++;
}
队列:
void EnQueue(SqQueue* q, int n, int t1)
{if (QueueFull(q)){return;}q->data[q->tail].CarNo = n;q->data[q->tail].CarTime = t1;//入队成功后,尾指针指向下一个位置q->tail = (q->tail + 1) % MAXSIZE_Qu;
}
⑥出栈/队列
栈:
void Pop(SqStack* s)
{if (StackEmpty(s)){printf("停车场为空\n");return;}s->top--;s->size--;
}
队列:
void DeQueue(SqQueue* q)
{if (QueueEmpty(q)){return;//队列为空}//出队成功后,头指针指向下一个位置q->top = (q->top + 1) % MAXSIZE_Qu;
}
⑦打印
栈:
void DispStack(SqStack* s)
{//对栈是否为空进行判断if (StackEmpty(s)){printf("停车场中没有车辆\n");return;}//循环打印停车场中的元素int i = 0;printf("停车场中共%d辆车,还有%d个空位\n", StackLength(s), MAXSIZE_St -StackLength(s));printf("车牌号\t进场时间\n");//size-1是因为在入栈时size最后会自增指向空位置for (i = s->size - 1; i >= 0; i--){printf("%-4d\t%-2d\n", s->data[i].CarNo, s->data[i].CarTime);}
}
队列:
void DispQueue(SqQueue* q)
{if (QueueEmpty(q)){printf("便道上没有车辆\n");return;//队列为空}//循环打印便道(队列Q)中的元素int i = 0;printf("便道中共%d辆车\n", StackLength(q));printf("便道中的车辆: \n");for (i = 0; i < QueueLength(q); i++){//出队后头指针会向后走,所以头指针决定了元素的索引printf("车牌号 %d\n", q->data[i + q->top].CarNo);}
}
3、要求操作
①车辆到达
void Parking_Arrive(SqStack* s1, SqQueue* q)
{int n = 0; //车号int t1 = 0; //车的到达时间if (!StackFull(s1)){//停车场S1未满时printf("车号 到达时间: ");scanf("%d %d", &n, &t1);Push(s1, n, t1);printf("所在停车场位置: %d\n", s1->size);}else{//停车场S1已满时printf("车号 到达时间: ");scanf("%d %d", &n, &t1);EnQueue(q, n, t1);printf("所在便道位置: %d\n", (q->tail));}return;
}
②车辆离开
void Parking_Leave(SqStack* s1, SqStack* s2, SqQueue* q)
{int i = 0;int n = 0; //车号int t2 = 0; //车的离开时间int index = -1; //对应车号的索引int count = 0; //出栈入栈次数printf("车号 离开时间: ");scanf("%d %d", &n, &t2);//找到要离开的车,记录其索引for (i = s1->size - 1; i >= 0; i--){if (n == s1->data[i].CarNo){index = i;break;}}if (index == -1){printf("无对应车号的车辆!\n");return;}//说明离开的车所花停车费用int price = (t2 - s1->data[index].CarTime) * Parking_price;printf("该汽车的停车费用为: %d.\n", price);//将需要离开的车其后面的车移动到栈S2中for (i = s1->size - 1; i > index; i--){//将对应元素入栈到S2中后,再从S1中出栈Push(s2, s1->data[i].CarNo, s1->data[i].CarTime);Pop(s1);//每有一辆车进入S2则count加一count++;}//将离开的车(目前处于栈顶)出栈Pop(s1);//先将暂存S2中的车入栈到栈S1中(S2有车的情况下)for (i = count - 1; i >= 0; i--){//S2中的车入栈到S1中,再在S2中进行出栈Push(s1, s2->data[i].CarNo, s2->data[i].CarTime);Pop(s2);}//如果栈S1未满,则将便道Q的车入栈到S1中if (!StackFull(s1) && !QueueEmpty(q)){for (i = 0; i < MAXSIZE_St - s1->size; i++){//队列Q中的车入栈到S1中,再在Q中进行出队Push(s1, q->data[i + q->top].CarNo, q->data[i + q->top].CarTime);DeQueue(q);}}return;
}
4、主函数
int main()
{//初始化两个停车场栈(S1和S2)和一个便道队列(Q)SqStack* S1 = InitStack();SqStack* S2 = InitStack();SqQueue* Q = InitQueue();int select = 0; do {printf("请输入指令(1:车辆到达 2:车辆离开 3:停车场、便道信息 0:退出系统): ");scanf("%d", &select);switch (select){case 1:Parking_Arrive(S1, Q);break;case 2:Parking_Leave(S1, S2, Q);break;case 3:DispStack(S1);DispQueue(Q);break;case 0:printf("已退出系统!\n");break;default:printf("请重新输入\n");getchar();}} while (select);return 0;
}
3、代码整合
#define _CRT_SECURE_NO_WARNINGS
#include<stdlib.h>
#include<stdio.h>#define MAXSIZE_St 3//栈最大容量
#define MAXSIZE_Qu 100//队列最大容量
#define Parking_price 5 //停车费5/h//车辆信息
typedef struct Car
{int CarNo;//车牌号int CarTime;//车进入时间
}Car;//顺序栈(停车场和车辆离开时暂时需要进入的区域)
typedef struct SqStack
{Car* data;//车辆信息int top;//栈顶int size;//长度
}SqStack;//循环队列(便道)
typedef struct SqQueue
{Car* data;//车辆信息int top;//队头int tail;//队尾int size;//长度
}SqQueue;//初始化栈
SqStack* InitStack()
{SqStack* s = (SqStack*)malloc(sizeof(SqStack));s->data = (Car*)malloc(sizeof(Car) * MAXSIZE_St);if (s->data == NULL || s->data == NULL){return NULL;}s->size = 0;s->top = 0;//表示栈为空return s;
}//检查栈是否为空,即停车场是否无车。
int StackEmpty(SqStack* s)
{if (s->top == 0)return 1;//为空elsereturn 0;//不为空
}//检查栈是否已满,即停车场是否已满。
int StackFull(SqStack* s)
{if (s->size != MAXSIZE_St)return 0;//未满elsereturn 1;//已满
}//计算栈的长度,即停车场内车辆数量。
int StackLength(SqStack* s)
{return s->size;
}//将新车辆加入到栈(停车场)中。
void Push(SqStack* s, int n, int t1)
{s->data[s->top].CarNo = n;s->data[s->top].CarTime = t1;s->top++;s->size++;
}//从栈中移除车辆。
void Pop(SqStack* s)
{if (StackEmpty(s)){printf("停车场为空\n");return;}s->top--;s->size--;
}//显示栈中的所有车辆信息。
void DispStack(SqStack* s)
{//对栈是否为空进行判断if (StackEmpty(s)){printf("停车场中没有车辆\n");return;}//循环打印停车场中的元素int i = 0;printf("停车场中共%d辆车,还有%d个空位\n", StackLength(s), MAXSIZE_St -StackLength(s));printf("车牌号\t进场时间\n");//size-1是因为在入栈时size最后会自增指向空位置for (i = s->size - 1; i >= 0; i--){printf("%-4d\t%-2d\n", s->data[i].CarNo, s->data[i].CarTime);}
}//初始化队列
SqQueue* InitQueue()
{SqQueue* q = malloc(sizeof(SqQueue));q->data = (Car*)malloc(sizeof(Car) * MAXSIZE_Qu);if (!q || !(q->data)){return NULL;}//初始头指针和尾指针指向0索引q->top = q->tail = 0;return q;
}//检查队列是否为空,即便道是否无车。
int QueueEmpty(SqQueue* q)
{if (q->top == q->tail){return 1;//为空}return 0;//不为空
}//检查队列是否已满,即便道是否已满。
int QueueFull(SqQueue* q)
{return ((q->tail + 1) % MAXSIZE_Qu == q->top) ? 1 : 0;
}int QueueLength(SqQueue* q)
{return (q->tail - q->top + MAXSIZE_Qu) % MAXSIZE_Qu;
}//将新车辆加入到队列中。
void EnQueue(SqQueue* q, int n, int t1)
{if (QueueFull(q)){return;}q->data[q->tail].CarNo = n;q->data[q->tail].CarTime = t1;//入队成功后,尾指针指向下一个位置q->tail = (q->tail + 1) % MAXSIZE_Qu;
}//从队列中移除车辆。
void DeQueue(SqQueue* q)
{if (QueueEmpty(q)){return;//队列为空}//出队成功后,头指针指向下一个位置q->top = (q->top + 1) % MAXSIZE_Qu;
}//显示队列中的所有车辆信息。
void DispQueue(SqQueue* q)
{if (QueueEmpty(q)){printf("便道上没有车辆\n");return;//队列为空}//循环打印便道(队列Q)中的元素int i = 0;printf("便道中共%d辆车\n", StackLength(q));printf("便道中的车辆: \n");for (i = 0; i < QueueLength(q); i++){//出队后头指针会向后走,所以头指针决定了元素的索引printf("车牌号 %d\n", q->data[i + q->top].CarNo);}
}void Parking_Arrive(SqStack* s1, SqQueue* q)
{int n = 0; //车号int t1 = 0; //车的到达时间if (!StackFull(s1)){//停车场S1未满时printf("车号 到达时间: ");scanf("%d %d", &n, &t1);Push(s1, n, t1);printf("所在停车场位置: %d\n", s1->size);}else{//停车场S1已满时printf("车号 到达时间: ");scanf("%d %d", &n, &t1);EnQueue(q, n, t1);printf("所在便道位置: %d\n", (q->tail));}return;
}void Parking_Leave(SqStack* s1, SqStack* s2, SqQueue* q)
{int i = 0;int n = 0; //车号int t2 = 0; //车的离开时间int index = -1; //对应车号的索引int count = 0; //出栈入栈次数printf("车号 离开时间: ");scanf("%d %d", &n, &t2);//找到要离开的车,记录其索引for (i = s1->size - 1; i >= 0; i--){if (n == s1->data[i].CarNo){index = i;break;}}if (index == -1){printf("无对应车号的车辆!\n");return;}//说明离开的车所花停车费用int price = (t2 - s1->data[index].CarTime) * Parking_price;printf("该汽车的停车费用为: %d.\n", price);//将需要离开的车其后面的车移动到栈S2中for (i = s1->size - 1; i > index; i--){//将对应元素入栈到S2中后,再从S1中出栈Push(s2, s1->data[i].CarNo, s1->data[i].CarTime);Pop(s1);//每有一辆车进入S2则count加一count++;}//将离开的车(目前处于栈顶)出栈Pop(s1);//先将暂存S2中的车入栈到栈S1中(S2有车的情况下)for (i = count - 1; i >= 0; i--){//S2中的车入栈到S1中,再在S2中进行出栈Push(s1, s2->data[i].CarNo, s2->data[i].CarTime);Pop(s2);}//如果栈S1未满,则将便道Q的车入栈到S1中if (!StackFull(s1) && !QueueEmpty(q)){for (i = 0; i < MAXSIZE_St - s1->size; i++){//队列Q中的车入栈到S1中,再在Q中进行出队Push(s1, q->data[i + q->top].CarNo, q->data[i + q->top].CarTime);DeQueue(q);}}return;
}int main()
{//初始化两个停车场栈(S1和S2)和一个便道队列(Q)SqStack* S1 = InitStack();SqStack* S2 = InitStack();SqQueue* Q = InitQueue();int select = 0; do {printf("请输入指令(1:车辆到达 2:车辆离开 3:停车场、便道信息 0:退出系统): ");scanf("%d", &select);switch (select){case 1:Parking_Arrive(S1, Q);break;case 2:Parking_Leave(S1, S2, Q);break;case 3:DispStack(S1);DispQueue(Q);break;case 0:printf("已退出系统!\n");break;default:printf("请重新输入\n");getchar();}} while (select);return 0;
}
相关文章:
数据结构——停车场管理问题
目录 1、问题描述2、逐步分析1)涉及操作2)代码实现 3、代码整合 1、问题描述 1、题目 设停车场内只有一个可停放n辆汽车的狭长通道,且只有一个大门可供汽车进出。汽车在停车场内按车辆到达时间的先后顺序,依次由北向南排列&#x…...
道品智能科技移动式水肥一体机:农业灌溉施肥的革新之选
在现代农业的发展进程中,科技的力量正日益凸显。其中,移动式水肥一体机以其独特的可移动性、智能化以及实现水肥一体化的卓越性能,成为了农业领域的一颗璀璨新星。它不仅改变了传统的农业灌溉施肥方式,更为农业生产带来了高效、精…...
AI实习--常用的Linux命令
一、基础命令 1. 切换到根目录。 cd ~ 2. 返回上一级目录。 cd .. 3. 查看当前目录下包括哪些文件和文件夹。 ls 4. 查看当前路径。 pwd 5. 将文件或文件夹剪切到目标目录下。 mv 文件所在路径 目标路径 6. 查看文本文件内容。 cat 文本文件名 7. 创建文件或文件夹…...
Python学习指南 + 谷歌浏览器如何安装插件
找往期文章包括但不限于本期文章中不懂的知识点: 个人主页:我要学编程(ಥ_ಥ)-CSDN博客 所属专栏: Python 目录 前言 Python 官方文档的使用 谷歌浏览器中如何安装插件 前言 在学习Python时,我们可能会出现这样的困惑&#x…...
研0找实习【学nlp】15---我的后续,总结(暂时性完结)
当下进展成果: nlptransformerpytorchhuggingfacebert简历环境配置表情识别文本分类 断更了快1个月,2个礼拜找实习,1个礼拜伤心,1个礼拜想我要干什么…… 承认自己的才疏学浅,了解了leetcode,和老师商量了…...
kylin麒麟银河桌面版操作系统安装部署
本文主要描述kylin麒麟银河桌面版操作系统的安装,该操作系统的安装源文件可以从kylin麒麟银河官方网站上下载,商业版本需要申请试用,开源版本可以直接下载使用。 如上所示,x86芯片处理器架构的请下载INTEL版本,华为海思…...
MyBatis插件原理及应用
🎮 作者主页:点击 🎁 完整专栏和代码:点击 🏡 博客主页:点击 文章目录 介绍<plugins>标签解析拦截器链的工作原理插件的应用场景MyBatis插件应用的四个组件InterceptorChain和Interceptor MyBatis框架…...
[M最短路] lc743. 网络延迟时间(spfa最短路+单源最短路)
文章目录 1. 题目来源2. 题目解析 1. 题目来源 链接:743. 网络延迟时间 相关链接: [图最短路模板] 五大最短路常用模板) 2. 题目解析 怎么讲呢,挺抽象的…很久没写最短路算法了。反正也是写出来了,但脱离了模板,把…...
MySQL 中的锁
MySQL 中的锁:全面解析与应用指南 在 MySQL 数据库的复杂世界里,锁是确保数据一致性、完整性以及并发控制的关键机制。无论是简单的小型应用还是复杂的企业级系统,深入理解 MySQL 中的锁对于优化数据库性能、避免数据冲突和错误都具有至关重要…...
【动手学电机驱动】STM32-FOC(8)MCSDK Profiler 电机参数辨识
STM32-FOC(1)STM32 电机控制的软件开发环境 STM32-FOC(2)STM32 导入和创建项目 STM32-FOC(3)STM32 三路互补 PWM 输出 STM32-FOC(4)IHM03 电机控制套件介绍 STM32-FOC(5&…...
【C++11】尽显锋芒
(续) 一、可变参数模板 C11支持可变参数模板,也就是说支持可变数量参数的函数模板和类模板,可变数目的参数被称 为参数包,存在两种参数包:模板参数包,表示零或多个模板参数;函数参数包:表示零…...
掌握控制流的艺术:Go语言中的if、for和switch语句
标题:掌握控制流的艺术:Go语言中的if、for和switch语句 在Go语言的编程世界中,控制流语句是构建程序逻辑的基石。if语句、for循环和switch语句是我们最常用的控制流工具,它们让我们能够根据不同的条件执行不同的代码块。本文将深入探讨这些语句的使用方法、技术细节和实际…...
飞书会话消息左右排列
飞书会话消息左右排列 1. 飞书登录后,点击头像,弹出菜单有个按钮设置 2. 3....
.net 支持跨平台(桌面)系列技术汇总
1. 首先微软老大哥的.net core 。 .NET Core 是微软开发的一个跨平台、高性能的开源框架,用于构建云和互联网连接的新型应用。 它允许开发者在 Windows、macOS 和 Linux 上使用喜爱的开发工具进行开发,并支持部署到云或本地环境。 .NET Core 是对 .NET …...
springboot 静态资源访问
最近在学习springboot,在学习中一个静态资源访问,难道了我三天,在网上找了很多的资料,又是配置,又是重写WebMvcConfigurationSupport,因为以前没有接触,本来很简单的事情走了很多弯路࿰…...
【linux学习指南】初识Linux进程信号与使用
文章目录 📝信号快速认识📶⽣活⻆度的信号📶 技术应⽤⻆度的信号🌉 前台进程(键盘)🌉⼀个系统函数 📶信号概念📶查看信号 🌠 信号处理🌉 忽略此信…...
L1G1000 书生大模型全链路开源开放体系笔记
关卡任务 观看本关卡视频后,写一篇关于书生大模型全链路开源开放体系的笔记。 视频链接:【书生浦语大模型全链路开源体系】 : 书生浦语大模型开源开放体系_哔哩哔哩_bilibili 书生大模型全链路开源开放体系笔记 在人工智能领域,大模型的…...
亚信安全与飞书达成深度合作
近日,亚信安全联合飞书举办的“走近先进”系列活动正式走进亚信。活动以“安全护航信息化 共筑数字未来路”为主题,吸引了众多数字化转型前沿企业的近百位领导参会。作为“走近先进”系列的第二场活动,本场活动更加深入挖掘了数字化转型的基础…...
深入讲解Spring Boot和Spring Cloud,外加图书管理系统实战!
很抱歉,我的疏忽,说了这么久还没有给大家详细讲解过Spring Boot和Spring Cloud,那今天给大家详细讲解一下。 大家可以和下面这三篇博客一起看: 1、Spring Boot 和 Spring Cloud 微服务开发实践详解https://blog.csdn.net/speaking_me/artic…...
【三维生成】Edify 3D:可扩展的高质量的3D资产生成(英伟达)
标题:Edify 3D: Scalable High-Quality 3D Asset Generation 项目:https://research.nvidia.com/labs/dir/edify-3d demo:https://build.nvidia.com/Shutterstock/edify-3d 文章目录 摘要一、前言二、多视图扩散模型2.1.消融研究 三、重建模型…...
【OSG学习笔记】Day 18: 碰撞检测与物理交互
物理引擎(Physics Engine) 物理引擎 是一种通过计算机模拟物理规律(如力学、碰撞、重力、流体动力学等)的软件工具或库。 它的核心目标是在虚拟环境中逼真地模拟物体的运动和交互,广泛应用于 游戏开发、动画制作、虚…...
(二)TensorRT-LLM | 模型导出(v0.20.0rc3)
0. 概述 上一节 对安装和使用有个基本介绍。根据这个 issue 的描述,后续 TensorRT-LLM 团队可能更专注于更新和维护 pytorch backend。但 tensorrt backend 作为先前一直开发的工作,其中包含了大量可以学习的地方。本文主要看看它导出模型的部分&#x…...
Python实现prophet 理论及参数优化
文章目录 Prophet理论及模型参数介绍Python代码完整实现prophet 添加外部数据进行模型优化 之前初步学习prophet的时候,写过一篇简单实现,后期随着对该模型的深入研究,本次记录涉及到prophet 的公式以及参数调优,从公式可以更直观…...
【决胜公务员考试】求职OMG——见面课测验1
2025最新版!!!6.8截至答题,大家注意呀! 博主码字不易点个关注吧,祝期末顺利~~ 1.单选题(2分) 下列说法错误的是:( B ) A.选调生属于公务员系统 B.公务员属于事业编 C.选调生有基层锻炼的要求 D…...
【论文阅读28】-CNN-BiLSTM-Attention-(2024)
本文把滑坡位移序列拆开、筛优质因子,再用 CNN-BiLSTM-Attention 来动态预测每个子序列,最后重构出总位移,预测效果超越传统模型。 文章目录 1 引言2 方法2.1 位移时间序列加性模型2.2 变分模态分解 (VMD) 具体步骤2.3.1 样本熵(S…...
九天毕昇深度学习平台 | 如何安装库?
pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子: 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...
VM虚拟机网络配置(ubuntu24桥接模式):配置静态IP
编辑-虚拟网络编辑器-更改设置 选择桥接模式,然后找到相应的网卡(可以查看自己本机的网络连接) windows连接的网络点击查看属性 编辑虚拟机设置更改网络配置,选择刚才配置的桥接模式 静态ip设置: 我用的ubuntu24桌…...
SQL慢可能是触发了ring buffer
简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的“no matching...“系列算法协商失败问题
【SSH疑难排查】轻松解决新版OpenSSH连接旧服务器的"no matching..."系列算法协商失败问题 摘要: 近期,在使用较新版本的OpenSSH客户端连接老旧SSH服务器时,会遇到 "no matching key exchange method found", "n…...
【Linux】Linux安装并配置RabbitMQ
目录 1. 安装 Erlang 2. 安装 RabbitMQ 2.1.添加 RabbitMQ 仓库 2.2.安装 RabbitMQ 3.配置 3.1.启动和管理服务 4. 访问管理界面 5.安装问题 6.修改密码 7.修改端口 7.1.找到文件 7.2.修改文件 1. 安装 Erlang 由于 RabbitMQ 是用 Erlang 编写的,需要先安…...
