左神算法基础class3-2—题目3仅用栈结构实现队列结构

2023-12-07 19:18

本文主要是介绍左神算法基础class3-2—题目3仅用栈结构实现队列结构,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

左神算法基础class3-2—题目3仅用栈结构实现队列结构

  • 1.题目
  • 2.分析
  • 3.核心代码
  • 4.完整代码
  • 5.输出结果

1.题目

如何仅用栈结构实现队列结构?

2.分析

栈本身是先进后出的结构,要想实现先进先出队列的作用就需要两个栈,把一个栈先倒到另一个栈内再pop出来。
(1)设计两个栈,一个命名为push、一个为pop。把数据输入push栈,把从pop栈输出的数据作为队列的输出结果。
在这里插入图片描述
(2)需要输出时,需要先把push栈的内容全部倒入pop栈,再把pop的栈顶输出。
Tips:把push栈倒入pop栈需要满足下列条件:
①push倒的时候必须要倒完
②pop内有东西则不能倒

3.核心代码

根据push和pop栈空与非空可分为三种情况:
①push、pop都空则直接return;
②pop非空则不倒直接输出;
③push不空,pop空则倒入再输出;

void pop_num(stack<int> &pushstack,stack<int> &popstack){if(popstack.empty() && pushstack.empty()){cout<<"空"<<endl;return;}if(popstack.empty()){while(!pushstack.empty()){popstack.push(pushstack.top());pushstack.pop();}}cout<< popstack.top() <<endl;popstack.pop();}

4.完整代码

#include<stack>
#include<iostream>
using namespace std;void pop_num(stack<int> &pushstack,stack<int> &popstack){if(popstack.empty() && pushstack.empty()){cout<<"空"<<endl;return;}if(popstack.empty()){while(!pushstack.empty()){popstack.push(pushstack.top());pushstack.pop();}}cout<< popstack.top() <<endl;popstack.pop();}
int main()
{stack<int> pushstack;stack<int> popstack;pushstack.push(1);pushstack.push(2);pushstack.push(3);pop_num(pushstack,popstack);pop_num(pushstack,popstack);pushstack.push(4);pop_num(pushstack,popstack);pushstack.push(5);pop_num(pushstack,popstack);pop_num(pushstack,popstack);pop_num(pushstack,popstack);system("pause");return 0;
}

5.输出结果

输入1,2,3,4,5时不管在什么位置倒入pop栈,输出顺序一定是1,2,3,4,5
在这里插入图片描述

这篇关于左神算法基础class3-2—题目3仅用栈结构实现队列结构的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle

SpringKafka错误处理(重试机制与死信队列)

《SpringKafka错误处理(重试机制与死信队列)》SpringKafka提供了全面的错误处理机制,通过灵活的重试策略和死信队列处理,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、Spring Kafka错误处理基础二、配置重试机制三、死信队列实现四、特定异常的处理策略五

SpringSecurity JWT基于令牌的无状态认证实现

《SpringSecurityJWT基于令牌的无状态认证实现》SpringSecurity中实现基于JWT的无状态认证是一种常见的做法,本文就来介绍一下SpringSecurityJWT基于令牌的无... 目录引言一、JWT基本原理与结构二、Spring Security JWT依赖配置三、JWT令牌生成与

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

MySQL更新某个字段拼接固定字符串的实现

《MySQL更新某个字段拼接固定字符串的实现》在MySQL中,我们经常需要对数据库中的某个字段进行更新操作,本文就来介绍一下MySQL更新某个字段拼接固定字符串的实现,感兴趣的可以了解一下... 目录1. 查看字段当前值2. 更新字段拼接固定字符串3. 验证更新结果mysql更新某个字段拼接固定字符串 -