利用栈去实现队列

news2025/1/13 10:23:05

利用栈实现队列

今天我们利用两个栈去实现队列(因为是用c去实现队列没有c++中的库函数所以我们要先手搓一个栈再去使用)

没有实现的去看我的这篇文章:利用顺序表对栈的实现-CSDN博客

回顾一下特性:栈----先进后出、后进先出,队列---先进先出。

实现的大体思路:

                          1、在存储数据时把数据存储到push中,因为栈是先进后出把push中的数据交换到pop中然后再利用pop函数进行导出即可。

定义结构体:

                   利用结构体去管理两个栈。

代码实现:
typedef struct {
    ST push;
    ST pop;
} MyQueue;

初始化栈

思路解析:

                因为是局部定义的变量,出作用域会自动销毁,所以在要在开辟一个空间(大小就是两个栈的大小)

代码实现:
MyQueue* myQueueCreate() {
    MyQueue*obj=(MyQueue*)malloc(sizeof(MyQueue));

    STInit(&obj->push);
    STInit(&obj->pop);
    return obj;
}

插入数据

思路解析:

                1、利用push函数在push的栈中插入数据

                2、在实现push的栈时要用malloc函数进行扩容然后再进行插入。

代码展示:

                (这里是调用了上面手搓的push函数有需要的可以看看)

void myQueuePush(MyQueue* obj, int x) {
    STPush(&obj->push,x);
}

查看最顶上面的数据

思路解析:

                这里就顺便导数据利用上empty函数对两个栈里面进行判断pop是否为空,pop是空就把push的数据导过去,不是空就返回push的数据。

代码展示:
int myQueuePeek(MyQueue* obj) {
    if(!STEmpty(&obj->pop))
    {
        return STTop(&obj->pop);
    }
    else
    {
        while(!STEmpty(&obj->push))
        {
            STPush(&obj->pop,STTop(&obj->push));
            STPop(&obj->push);
        }
        return STTop(&obj->pop);
    }
}

弹出数据

思路解析:

                利用查找栈顶数据的函数查找并存储到变量中利用pop函数弹出数据并返回存储变量。

代码展示:
int myQueuePop(MyQueue* obj) {
    int top=myQueuePeek(obj);
    STPop(&obj->pop);
    return top;
}

对栈进行判断

思路解析:

                利用empty函数对pop和push函数进行判断并利用bool进行返回

代码展示:
bool myQueueEmpty(MyQueue* obj) {
    return STEmpty(&obj->pop)&&STEmpty(&obj->push);
}

栈的销毁

思路解析:

                利用destroy函数对结构体里面的栈进行销毁然后对obj进行free即可。

代码展示:
void myQueueFree(MyQueue* obj) {
    STDestroy(&obj->pop);
    STDestroy(&obj->push);

    free(obj);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2036793.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

我常用的几个傻瓜式爬虫工具,收藏!

爬虫类工具主要两种,一种是编程语言第三方库,比如Python的scrapy、selenium等,需要有一定的代码基础,一种是图形化的web或桌面应用,比如Web Scraper、后羿采集器、八爪鱼采集器、WebHarvy等,接近于傻瓜式操…

汇量科技Mintegral发布全新产品矩阵:助力广告主高效增长与变现

近期,汇量科技旗下程序化互动式广告平台Mintegral正式推出全新产品命名,期望通过简洁明确的产品名称,更好地传达Mintegral的品牌理念,使客户与平台的每一次接触都更加直接高效。 Mintegral AppGrowth(原Mintegral Self-Service Pl…

【idea】 已经commit还没push怎么修改commit信息?

前言: 有时候填写commit信息时手快确认了,要push时发现信息有误,此时想重新更改信息。 此方法适用于在idea里commit了的,且还未push。 (u1s1,用idea来推送真的又快又方便,自此之后再也没碰过小乌…

Leetcode面试经典150题-112.路径总和

解法都在代码里,不懂就留言或者私信 超级简单的题,不过有隐形的坑 /*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.v…

算法定制与双光谱技术融合:提升巡检车入侵检测系统效能

一、应用背景 在当今数字化和信息化时代,算法已经成为企业提高效率、优化决策的重要工具。随着大数据、人工智能技术的迅速发展,客户对算法的需求呈现出爆发式增长。这种需求不仅体现在数量上,更体现在质量上,尤其是对算法定制化…

Dav_笔记13:SQL Access Advisor 之 1 Summary

SQL Access Advisor概述 SAA Summary 在调整数据库以实现复杂的数据密集型查询的最佳性能时,物化视图,分区和索引是必不可少的。 SQL Access Advisor通过为给定工作负载推荐适当的物化视图集,物化视图日志,分区和索引,…

macOS Sequoia 15 beta 5 (24A5309e) Boot ISO 原版可引导镜像下载

macOS Sequoia 15 beta 5 (24A5309e) Boot ISO 原版可引导镜像下载 iPhone 镜像、Safari 浏览器重大更新、备受瞩目的游戏和 Apple Intelligence 等众多全新功能令 Mac 使用体验再升级 请访问原文链接:https://sysin.org/blog/macOS-Sequoia-boot-iso/&#xff0c…

基于JAVA的外来人口管理系统设计与实现,源码、部署+讲解

摘 要 在新型冠状病毒性肺炎流行的背景下,我国数亿流动人口应该受到高度关注和保护。并让这一易感染人群离开成为“受害者传染源”的双重风险,的确是一项关键而富有挑战性的任务。因此,本毕业设计是以规模复杂的外来人口及居民群体为典例&am…

UI-无限循环列表

无限循环列表 创建 在任意节点上,添加Scroller,ScrollView组件,和RectMask2D组件: 其中列表的大小,依赖Rect的大小。 界面参数介绍 ViewPort:视口大小 SrollDirction:滚动方向 MovementType&#xff1a…

go语言后端开发学习(五)——如何在项目中使用Viper来配置环境

前言 在之前的文章中我们就介绍过用go-ini来读取配置文件,但是当时我们在介绍时说了他只能读取.ini格式的配置文件所以局限性较大,这里我们介绍一个适用范围更大的配置管理第三方库——Viper。 什么是Viper Viper是适用于Go应用程序(包括Twelve-Factor App&#…

算法-差分, 二维前缀和, 离散化

文章目录 本节提要1. 一维差分1.1 一维差分原理分析1.2 一维差分例题应用 2. 等差数列差分2.1 等差数列差分原理分析 3. 二维前缀和3.1 二维前缀和原理分析3.2 二维前缀和例题应用 本节提要 本节的主要目标是一维差分的总结, 包括一维差分, 一维等差数列差分; 二维差分和二维前…

唐诡探案外传-MySQL误操作之“寻凶”

序幕:字符集被修改之谜 立秋后的第一天下午,太阳仍不知疲倦地炙烤着大地,办公室内的中央空调不停歇地鼓吹着冷风。某办公楼内,IT部门的阿祖被同事急匆匆地找来,说是系统出现了奇怪的bug,追查之下发现测试环…

搭建高可用OpenStack(Queen版)集群(十二)之启动一个实例

一、搭建高可用OpenStack(Queen版)集群之启动一个实例 创建实例之前,首先要创建虚拟网络 一、创建网络 建议命令行和web管理协同进行配置,这样不容易出错 在控制节点执行 1、创建公有网络部分 1、在命令行执行 . admin-openrc ne…

【SQL】平均售价

目录 题目 分析 代码 题目 表:Prices ------------------------ | Column Name | Type | ------------------------ | product_id | int | | start_date | date | | end_date | date | | price | int | ---------------…

技术研究:Redis 数据结构与 I/O 模型

数据结构 Redis之所以“快”,一方面因为它是内存数据库,所有操作都在内存上完成,内存的访问速度本来就快。另一方面则是因为高效的数据结构,使得操作键值效率较高。总体来说,Redis使用了一个用来保存每个Key/Value的全…

【Story】如何高效记录并整理编程学习笔记?

目录 一、为何笔记在编程学习中如此重要?1.1 知识的捕捉1.2 理解和消化1.3 知识的复习1.4 知识的分享 二、建立高效的笔记系统2.1 确定笔记的目标2.2 选择合适的工具2.3 笔记的结构化2.4 记录有效的内容2.5 定期回顾和更新 三、保持笔记条理性的技巧3.1 使用一致的格…

【数据结构】堆排序与TOP-K问题

🌈个人主页:Yui_ 🌈Linux专栏:Linux 🌈C语言笔记专栏:C语言笔记 🌈数据结构专栏:数据结构 文章目录 1.堆排序1.1 建堆1.2 利用堆删除思想来进行排序1.3 堆排序的时间复杂度 2.TOP-K问…

Uniapp之微信小程序计算器

UI仿的iOS手机计算器,基本功能已经实现,如下效果图 具体使用可以参考微信小程序:日常记一记--我的---计算器 第一步:UI界面设计 1,strClass模块是计算过程代码展示 2,result-view模块是结果展示 3&#xff…

嵌入式学习---DAY24:进程--二

一、exec函数族----启动一个新程序 用fork创建子进程后执行的是和父进程相同的程序(但有可能执行不同的代码分支), 子进程往往要调用一种exec函数以执行另一个程序。当进程调用一种exec函数时,该进程的 用户空间代码和数据完全被…

SHT30温湿度传感器全解析——概况,性能,MCU连接,样例代码

常见温湿度传感器测量范围:(价格仅供参考,具体性能要看折线图) 型号DHT11DHT20AHT10AHT20AHT30SHT20价格¥ 2.49¥3.04¥ 1.9¥1.4¥ 1.3¥5.5温度测量范围20—90%RH0—100%RH0—100%RH0—…