leetcode:225. 用队列实现栈
一、题目
链接:225. 用队列实现栈 - 力扣(LeetCode)
函数原型:
typedef struct {
} MyStack;
MyStack* myStackCreate()
void myStackPush(MyStack* obj, int x)
int myStackPop(MyStack* obj)
int myStackTop(MyStack* obj)
bool myStackEmpty(MyStack* obj)
void myStackFree(MyStack* obj)
二、思路
利用队列实现栈:
1.我的栈的结构
“我的栈”是一个结构体,存放两个队列即可
2.我的栈创建及其初始化
函数返回值是“我的栈”结构体指针,动态申请一个“我的栈”大小内存空间,然后初始化“我的栈”结构体中中的两个队列,最后返回“我的栈”的结构体指针
3.我的栈入栈
“我的栈”中有两个队列,选择一个空队列进行存储数据。由于栈的入栈和队列的入队都是从尾部进行存储数据的,所以直接对空队列进行入队操作即可。
如何找到空队列?
利用假设法,假设q1为空队列,q2为非空队列;判断q1是否为空,如果不为空,则将空队列设为q2,非空队列设为q1.
4.我的栈出栈
由于栈删除元素是从栈顶删除,而队列删除元素是从队头删除,所以需要先将非空队列中的前n-1个元素出队并入队到空队列中,第n个元素直接出队无需入队。即可完成“我的栈”的出栈。
5.我的栈取栈顶元素
取栈顶元素是在栈尾部进行的,所以可以对非空队列的取队尾元素。
6.我的栈判空
只要对两个队列判空即可,只有当两个队列都为空时,“我的栈”才判断为空。
7.我的栈销毁
首先对“我的栈”中两个队列进行队列销毁,然后再对动态申请的“我的栈”空间进行动态内存释放。
三、代码
typedef int QDataType;//队列的结构定义 typedef struct QueueNode{QDataType val;struct QueueNode *next; }QNode;//用结构体管理队列 typedef struct Queue{QNode* phead;QNode* ptail;int size; }Queue;//队列的初始化 void QueueInit(Queue* pq) {pq->phead=NULL;pq->ptail=NULL;pq->size=0; }//入队 void QueuePush(Queue *pq,QDataType x) {assert(pq);QNode *newnode=(QNode*)malloc(sizeof(QNode));if(newnode==NULL){perror("malloc fail");exit(-1);}newnode->val=x;newnode->next=NULL;if(pq->phead==NULL)//队列为空pq->phead=pq->ptail=newnode;else{pq->ptail->next=newnode;pq->ptail=newnode;}pq->size++; }//出队 void QueuePop(Queue* pq) {assert(pq);assert(pq->phead);//空队列if(pq->phead==pq->ptail){pq->ptail=NULL;}QNode* tmp=pq->phead;pq->phead=tmp->next;free(tmp);tmp=NULL;pq->size--; }//取队头元素 QDataType QueueFront(Queue* pq) {assert(pq);assert(pq->phead);return pq->phead->val; }//取队尾元素 QDataType QueueBack(Queue* pq) {assert(pq);assert(pq->ptail);return pq->ptail->val; }//判空 bool QueueEmpty(Queue *pq) {assert(pq);return pq->phead==NULL; }//销毁队列 void QueueDestroy(Queue* pq) {assert(pq);QNode *cur=pq->phead;while(cur){QNode* tmp=cur;cur=cur->next;free(tmp);tmp=NULL;}pq->phead=pq->ptail=NULL;pq->size=0; }typedef struct {Queue q1;Queue q2; } MyStack;//我的栈创建及其初始化 MyStack* myStackCreate() {MyStack *ps=(MyStack*)malloc(sizeof(MyStack));QueueInit(&ps->q1);QueueInit(&ps->q2);return ps; }void myStackPush(MyStack* obj, int x) {//利用假设法Queue *empty=&obj->q1;Queue *noneempty=&obj->q2;if(!QueueEmpty(&obj->q1)){empty=&obj->q2;noneempty=&obj->q1;}QueuePush(noneempty,x);//QueuePush(&obj->q1,x); }//我的栈-出栈 int myStackPop(MyStack* obj) {// while(obj->q1.size>1)// {// QueuePush(&obj->q2,QueueFront(&obj->q1));// QueuePop(&obj->q1);// //QueuePush(&obj->q2,QueuePop(&obj->q1));// }// int stackpop=QueueFront(&obj->q1);// QueuePop(&obj->q1);// while(obj->q2.size)// {// QueuePush(&obj->q1,QueueFront(&obj->q2));// QueuePop(&obj->q2);// //QueuePush(&obj->q1,QueuePop(&obj->q2));// }// return stackpop;//利用假设法Queue *empty=&obj->q1;Queue *noneempty=&obj->q2;if(!QueueEmpty(&obj->q1)){empty=&obj->q2;noneempty=&obj->q1;}while(noneempty->size>1){QueuePush(empty,QueueFront(noneempty));QueuePop(noneempty);}int stackpop=QueueFront(noneempty);QueuePop(noneempty);return stackpop; }//我的栈-出栈 int myStackTop(MyStack* obj) {Queue* empty=&obj->q1;Queue* noneempty=&obj->q2;if(!QueueEmpty(&obj->q1)){empty=&obj->q2;noneempty=&obj->q1;}return QueueBack(noneempty); }//我的栈-判空 bool myStackEmpty(MyStack* obj) {return QueueEmpty(&obj->q1)&&QueueEmpty(&obj->q2); }//我的栈-销毁 void myStackFree(MyStack* obj) {QueueDestroy(&obj->q1);QueueDestroy(&obj->q2);free(obj); }/*** Your MyStack struct will be instantiated and called as such:* MyStack* obj = myStackCreate();* myStackPush(obj, x);* int param_2 = myStackPop(obj);* int param_3 = myStackTop(obj);* bool param_4 = myStackEmpty(obj);* myStackFree(obj); */
相关文章:
leetcode:225. 用队列实现栈
一、题目 链接:225. 用队列实现栈 - 力扣(LeetCode) 函数原型: typedef struct { } MyStack; MyStack* myStackCreate() void myStackPush(MyStack* obj, int x) int myStackPop(MyStack* obj) int myStackTop(MyStack* obj) …...
Centos7安装GItLab(在线版)
基础环境准备 1.配置清华大学镜像仓库 新建仓库配置文件使用 vim /etc/yum.repos.d/gitlab-ce.repo 命令,输入以下内容,保存 [gitlab-ce] nameGitlab CE Repository baseurlhttps://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el$releasever/ gpgcheck0 enabl…...
Linux入门笔记
1 Linux概述 Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 UNIX 的多用户、多任务、支持多线程和多 CPU 的操作系统。Linux 能运行主要的 UNIX 工具软件、应用程序和网络协议。它支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心…...
nvm for windows使用与node/npm/yarn的配置
1 下载 nvm for windows download – github 下拉到Assets, 下载.exe文件 2 安装 安装到如下文件夹中 目录可以自己选, 可以换别的名字, 自己记住即可 新手建议全部看完再进行个人配置, 或者使用与博主一致的路径 D:\DevelopEnvironment\nvm3 配置nvm使用的镜像 node_mir…...
打工人副业变现秘籍,某多/某手变现底层引擎-StableDiffusionWebUI界面基本布局和操作
一、界面设置 文生图:根据文本提示生成图像 图生图:图像生成图像;功能很强大,自己在后续使用中探索。 后期处理:图片处理;功能很强大,自己在后续使用中探索。 PNG信息:这是一个快速获取图片生成参数的便捷功能。如果图像是在SD里生成的,您可以使用“发送到”按钮将…...
01、pytest:帮助你编写更好的程序
简介 pytest框架可以很容易地编写小型、可读的测试,并且可以扩展以支持应用程序和库的复杂功能测试。使用pytest至少需要安装Python3.7或PyPy3。PyPI包名称为pytest 一个快速的例子 # content of test_sample.py def inc(x):return x1def test_ansewer():asser…...
C语言--每日选择题--Day37
第一题 1. 有以下说明语句:则下面引用形式错误的是() struct Student {int num;double score; };struct Student stu[3] {{1001,80}, {1002,75}, {1003,91}} struct Student *p stu; A:p->num B:(p).num C&#…...
Android 12 及以上授权精确位置和模糊位置
请求位置信息权限 为了保护用户隐私,使用位置信息服务的应用必须请求位置权限。 请求位置权限时,请遵循与请求任何其他运行时权限相同的最佳做法。请求位置权限时的一个重要区别在于,系统中包含与位置相关的多项权限。具体请求哪项权限以及…...
scp 指令详细介绍
目录 1. 基本语法 2. 例子 从本地到远程 从远程到本地 从远程到远程 使用端口和指定私钥 递归复制目录 3. 注意事项 如何拷贝文件的软链接 SCP(Secure Copy Protocol)是一种用于在计算机之间安全地传输文件的协议。它通过加密的方式在网络上安全…...
构建第一个事件驱动型 Serverless 应用
我相信,我们从不缺精彩的应用创意,我们缺少的把这些想法变成现实的时间和付出。 我认为,无服务器技术真的有助于最大限度节省应用开发和部署的时间,并且无服务器技术用可控的成本,实现了我的那些有趣的想法。 在我 2…...
特征与特征图的区别
1.特征图是什么? 特征图是指在卷积神经网络中,通过卷积操作从输入图像中提取出来的图像特征。在卷积神经网络中,每一层的输出都是一个三维张量,其中第三维表示特征图的数量。每个特征图都是由若干个卷积核对上一层的特征图进行卷…...
Linux学习笔记之七(shell脚本的基本语法)
Shell 1、Shell脚本2、常用运算符2、特殊语法4、关于变量的一些命令4.1、echo4.2、export4.3、read4.4、declare/typeset4.5、local4.6、unset 5、基本逻辑语法5.1、if判断5.2、for循环5.3、while循环5.4、case语句 6、函数定义7、多脚本链接 1、Shell脚本 学习shell脚本开发之…...
PySpark开发环境搭建常见问题及解决
PySpark环境搭建常见问题及解决 1、winutils.exe问题2、SparkURL问题3、set_ugi()问题 本文主要收录PySpark开发环境搭建时常见的一些问题及解决方案,并收集一些相关资源 1、winutils.exe问题 报错摘要: WARN Shell: Did not find winutils.exe: {} ja…...
supervisor管理启动重启,Java,Go程序Demo
简介 Supervisor 是一款 Python 开发的进程管理系统,允许用户监视和控制 Linux 上的进程,能将一个普通命令行进程变为后台守护进程,异常退出时能自动重启 1、安装 yum -y install supervisor2、配置默认配置文件 echo_supervisord_conf &g…...
HarmonyOs 4 (三) ArkTS语言
目录 一 认识ArkTs语言1.1 ArkTs1.2 基本结构 二 基本语法2.1 声明式UI2.1.1 创建组件2.1.1.1 无参数2.1.1.2 有参数2.1.1.3 组件样式2.1.1.4 组件方法2.1.1.5 组件嵌套 2.1.2 自定义组件2.1.2.1 基本结构2.1.2.2 成员函数/变量2.1.2.3 自定义组件的参数规定2.1.2.4 Build函数2…...
PostGIS学习教程九:空间连接
PostGIS学习教程九:空间连接 空间连接(spatial joins)是空间数据库的主要组成部分,它们允许你使用空间关系作为连接键(join key)来连接来自不同数据表的信息。我们认为“标准GIS分析”的大部分内容可以表示…...
C++ day56 两个字符串的删除操作 编辑距离
题目1:583 两个字符串的删除操作 题目链接:两个字符串的删除操作 对题目的理解 返回使两个单词word1和word2相同的最少删除多少个元素,两个单词至少包含一个字母,且仅包含小写字母 思路1:这道题与昨天的不同子序列…...
Android studio中如何生成jar包?
文章目录 需求背景目录结构gradle结构makeJar的语法解析 执行makeJar 任务拿到jar包 需求背景 别部门做C语言开发的同学开发了一个库,需要给我们Android端去调用。 我们拿到源码,首先需要做的是通过CMake去把C源码编译链接成动态库。 当然静态库也行&am…...
【2】基于多设计模式下的同步异步日志系统-设计模式
6. 相关技术知识补充 6.1 不定参函数 在初学C语⾔的时候,我们都⽤过printf函数进⾏打印。其中printf函数就是⼀个不定参函数,在函数内部可以根据格式化字符串中格式化字符分别获取不同的参数进⾏数据的格式化。 ⽽这种不定参函数在实际的使⽤中也⾮常…...
第十五届蓝桥杯模拟赛B组(第二期)C++
前言: 第一次做蓝桥模拟赛的博客记录,可能有很多不足的地方,现在将第十五届蓝桥杯模拟赛B组(第二期)的题目与代码与大家进行分享,我是用C做的,有好几道算法题当时自己做的也是一脸懵,…...
人脸识别模型镜像实测:Retinaface+CurricularFace快速部署,效果超预期
人脸识别模型镜像实测:RetinafaceCurricularFace快速部署,效果超预期 1. 开箱即用的人脸识别解决方案 最近在测试各种人脸识别方案时,我偶然发现了CSDN星图平台上的RetinafaceCurricularFace镜像。这个预置环境让我眼前一亮——它不仅包含了…...
Qwen2-VL-2B-Instruct应用场景:智能硬件说明书图解与文字索引自动构建
Qwen2-VL-2B-Instruct应用场景:智能硬件说明书图解与文字索引自动构建 1. 引言:当说明书遇到AI,会发生什么? 你有没有过这样的经历?新买的智能设备到了,兴致勃勃地拆开包装,结果面对一本厚厚的…...
XYCOM XVME-564控制器模块
XYCOM XVME-564 控制器模块介绍XYCOM XVME-564 是一款基于 VME 总线架构的高性能模拟输入控制模块,主要用于工业自动化系统中的数据采集与过程监测。该模块在精度、采样速度以及灵活性方面表现突出,适用于对信号质量要求较高的应用场景。一、产品概述XVM…...
IDM下载效率翻倍!浏览器智能嗅探插件的5个高阶用法与避坑指南
IDM下载效率翻倍!浏览器智能嗅探插件的5个高阶用法与避坑指南 如果你已经使用过IDM浏览器智能嗅探插件,却依然觉得下载效率不够理想,这篇文章将带你解锁5个鲜为人知的高阶技巧。从资源去重算法优化到下载路径智能识别,这些方法能让…...
为什么92%的AI工程团队在MCP 2026AI集成中遭遇推理延迟突增?——基于17个真实客户集群的Trace数据建模分析与动态批处理调优公式
第一章:MCP 2026AI推理集成的行业现状与核心挑战当前,MCP(Model-Centric Pipeline)2026AI作为新一代面向边缘-云协同推理的标准化框架,已在智能驾驶、工业质检和实时医疗影像分析等高时效性场景中加速落地。然而&#…...
紧急!Dify v0.12.3升级后Token统计偏差达±34.7%——生产环境监控校准指南(附校验脚本+Diff测试用例)
第一章:紧急!Dify v0.12.3升级后Token统计偏差达34.7%——生产环境监控校准指南(附校验脚本Diff测试用例)Dify v0.12.3 版本在 token 计数器底层逻辑中引入了对 tiktoken 编码器的缓存策略变更,导致在含多语言混合、特…...
破大防!日本最大高性能“乐天AI3.0”被扒出基于DeepSeekV3架构
3月17日,日本乐天集团高调发布号称“日本国内最大规模高性能AI大模型”的Rakuten AI 3.0,宣称依托日本GENIAC国家项目支持、7000亿参数量实现日语场景性能突破,多项基准测试超越GPT-4o。然而发布仅数小时,这款被寄予“日本AI自主突…...
RabbitMQ和RocketMQ,哪个更好?
前言 最近有球友问我:苏三哥,现在一般的项目中的消息中间件,是用RabbitMQ,还是RocketMQ,更好? 这是一个非常常见的问题。 今天这篇文章就专门跟大家一起聊聊这个话题,希望对你会有所帮助。 …...
K6性能测试及生成Html压测报告
一、引言: k6是一款开源负载测试工具,由Grafana Labs开发维护,专注于现代云环境和微服务架构 的高并发压测。它采用Go语言编写,使用JavaScript(ES6)作为脚本语言。还提到它特别适合CI/CD集成和自动化性能测试。 二、下载安装&am…...
告别低效编辑!Vim代码编辑高级技巧与效率提升指南
告别低效编辑!Vim代码编辑高级技巧与效率提升指南 【免费下载链接】vim-galore-zh_cn Vim 从入门到精通 项目地址: https://gitcode.com/gh_mirrors/vi/vim-galore-zh_cn 你是否还在为代码编辑效率低下而烦恼?是否想掌握一款能让你手指不离键盘就…...
