(动画详解)LeetCode232.用栈实现队列

devtools/2024/9/23 6:21:54/

💖💖💖欢迎来到我的博客,我是anmory💖💖💖
又和大家见面了
欢迎来到动画详解LeetCode算法系列
用通俗易懂的动画让算法题不再神秘
先来自我推荐一波
个人网站欢迎访问以及捐款
推荐阅读
如何低成本搭建个人网站
专栏:动画详解leetcode算法
C语言知识

玉桂狗yay

题目描述

题目描述


解题思路

这道题我们引入两个,一个用来入,一个用来出
这样,出顶元素就是队列的队头元素了


动画详解

用<a class=栈实现队列" />


代码实现

这里由于使用的是C语言,需要自己写
所以代码量会比较多,大家不要被吓到了哈

typedef int DataType;// 定义一个,包含数据,顶元素下标,的大小
struct Stack
{DataType* data;int top;int capacity;
};typedef struct Stack Stack;// 的初始化
void StackInit(Stack* st)
{assert(st);st->data = NULL;st->capacity = 0;// top指向顶元素的下一个st->top = 0;
}// 入
void StackPush(Stack* st, DataType x)
{assert(st);if (st->top == st->capacity){int newcapacity = st->capacity == 0 ? 4 : st->capacity * 2;DataType* new = (DataType*)realloc(st->data,newcapacity*sizeof(DataType));// 如果开辟失败if (new == NULL){perror("malloc fail");return;}// 如果开辟成功st->data = new;st->capacity = newcapacity;}st->data[st->top] = x;st->top++;
}// 出
void StackPop(Stack* st)
{assert(st);st->top--;
}// 的判空
bool StackIsEmpty(Stack* st)
{assert(st);if (st->top == 0){return true;}else{return false;}
}// 返回顶元素
DataType StackTop(Stack* st)
{assert(st);assert(st->top > 0);return st->data[st->top - 1];
}// 的大小
int StackSize(Stack* st)
{assert(st);return st->top;
}// 的销毁
void StackDestroy(Stack* st)
{assert(st);free(st->data);st->data = NULL;st->top = st->capacity = 0;
}typedef struct 
{Stack pushst;Stack popst;
} MyQueue;MyQueue* myQueueCreate() 
{MyQueue* new = (MyQueue*)malloc(sizeof(MyQueue));StackInit(&(new->pushst));StackInit(&(new->popst));return new;}void myQueuePush(MyQueue* obj, int x) 
{StackPush(&(obj->pushst),x);}int myQueuePeek(MyQueue* obj);int myQueuePop(MyQueue* obj) 
{int front = myQueuePeek(obj);StackPop(&(obj->popst));return front;
}int myQueuePeek(MyQueue* obj) 
{if(StackIsEmpty(&(obj->popst))){// 导入数据while(!StackIsEmpty(&(obj->pushst))){int top = StackTop(&(obj->pushst));StackPush(&(obj->popst),top);StackPop(&(obj->pushst));}}return StackTop(&(obj->popst));}bool myQueueEmpty(MyQueue* obj) 
{return StackIsEmpty(&(obj->pushst)) && StackIsEmpty(&(obj->popst));}void myQueueFree(MyQueue* obj) 
{StackDestroy(&(obj->pushst));StackDestroy(&(obj->popst));free(obj);obj = NULL;}/*** Your MyQueue struct will be instantiated and called as such:* MyQueue* obj = myQueueCreate();* myQueuePush(obj, x);* int param_2 = myQueuePop(obj);* int param_3 = myQueuePeek(obj);* bool param_4 = myQueueEmpty(obj);* myQueueFree(obj);
*/

复杂度分析

O(n)啦


总结

💖💖💖非常感谢各位的支持💖💖💖
我们共同进步
本系列持续更新,关注我,带你手撕算法
下期再见
玉桂狗yay


http://www.ppmy.cn/devtools/41666.html

相关文章

华为涅槃,余承东重生

最近一段时间&#xff0c;余承东甚为低调。最为明显的是&#xff0c;“遥遥领先”已经听不到了&#xff0c;“余大嘴”口中的措辞越来越克制。 今后手机相关的发布会&#xff0c;或许不再看到余承东的身影。 5月10日&#xff0c;余承东的职位正式更新&#xff0c;从终端BG CE…

软考 系统架构设计师系列知识点之杂项集萃(7)

接前一篇文章&#xff1a;软考 系统架构设计师系列知识点之杂项集萃&#xff08;6&#xff09; 上一回在讲习题的时候引出来软件能力成熟度&#xff0c;由于内容较多&#xff0c;因此并未讲完&#xff0c;本回把剩余知识讲完。 软件能力成熟度模型 软件能力成熟度模型&#x…

Java面经学习2

来源 https://www.nowcoder.com/discuss/619573767051800576 1.一面内容 RocketMQ延时消息&#xff08;项目用到了&#xff09;底层怎么实现的&#xff08;不会&#xff09; 消息量太大导致读消息延迟时间很长怎么办 redis为什么快&#xff08;说了内存、数据结构优化、单线…

PCIE协议-2-事务层规范-Message Request Rules-Vendor_Defined Messages

2.2.8.6 厂商定义消息 厂商定义消息允许扩展PCI Express消息功能&#xff0c;可以作为PCI Express规范的一般扩展&#xff0c;也可以是厂商特定的扩展。本节通用地定义了与这些消息相关的规则。 厂商定义消息&#xff08;见表2-25&#xff09;使用图2-28中显示的头标格式。re…

【工具篇】-什么是.NET

“.NET"&#xff1a;.NET Core是由Microsoft开发&#xff0c;目前在.NET Foundation(一个非营利的开源组织)下进行管理。.NET Core是用C#和C编写的&#xff0c;并采用MIT协议作为开源协议。 简单来说&#xff1a;就是开发框架。 .NET 又称 .NET 平台或 .NET 框架&#xf…

k8s源码编译失败:Makefile:1: *** 缺失分隔符。 停止。

目录 问题解决 更换Arch或系统 问题解决 编译k8s源码的kubelet时执行make失败&#xff1a;Makefile:1: *** 缺失分隔符。 停止。 首先&#xff0c;查看文件内容 # cat Makefile build/root/Makefile 修改Makefile&#xff0c;给第一行前增加include&#xff0c;如下&…

Python3 笔记:循环结构 while语句

程序在一般情况下是按顺序执行的。编程语言提供了各种控制结构&#xff0c;允许更复杂的执行路径。循环语句允许我们多次执行一个语句或语句组。 while是Python语言中构造循环结构程序的语句之一&#xff0c;在Python语言中&#xff0c;虽然绝大多数的循环结构都是用for语句来…

“Linux”目录结构and配置网络

了解完命令格式和vi、vim编辑器后&#xff0c;我们来认识一下目录的结构&#xff1a; 一、目录 &#xff08;1&#xff09;目录的特点 windows特点&#xff1a; Windows中有C、D、E盘&#xff0c;每个都是一个根系统 Linux特点&#xff1a; linux中只有一个根&#xff08;单…