栈和队列操作:栈实现、队列实现、双栈实现队列、双队列实现栈、栈实现O(n)求当前栈最大值

2024-01-31 02:38

本文主要是介绍栈和队列操作:栈实现、队列实现、双栈实现队列、双队列实现栈、栈实现O(n)求当前栈最大值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

栈和队列操作
目录
  1. 栈实现
  2. 队列实现
  3. 双栈实现队列
  4. 双队列实现栈
  5. 栈实现O(n)求当前栈最大值

import java.util.Arrays;
import java.util.Comparator;
import java.util.Random;
/*
* shsheng
*/
public class StackAndQueue {
public static final int SIZE=10;
public static final int MAXSIZE=16*SIZE;
public static void main(String[] args) {
testQueue();
testStack();
testTwoQueueWorkStack();
testTwoStackWorkQueue();
testStackAndMax();
}
/*
* 用栈实现当前栈的最大值,时间复杂度O(n)
* 求解方法:双栈
*/
static class StackAndMax{
Stackstack=new Stack();
StackmaxStack=new Stack(); public boolean isEmpty(){ return stack.isEmpty(); } public void push(T data){ if(stack.isEmpty()){ maxStack.push(data); }else{ T max=maxStack.peek(); if((Integer)data>(Integer)max) max=data; maxStack.push(max); } stack.push(data); } public T pop(){ maxStack.pop(); return stack.pop(); } public T getMax(){ return maxStack.peek(); } } public static void testStackAndMax(){ StackAndMax stack=new StackAndMax (); Random random=new Random(); System.out.println("StackAndMax"); for(int i=0;i<10;i++){ int length=random.nextInt(30); for(int j=0;j { Stack enStack=new Stack (); Stack deStack=new Stack (); public boolean isEmpty(){ return enStack.isEmpty()&&deStack.isEmpty(); } public void enQueue(T data){ enStack.push(data); } public T deQueue(){ if(isEmpty()){ try { throw new Exception("Empty TwoStackWorkQueue!"); } catch (Exception e) { e.printStackTrace(); } } if(deStack.isEmpty()){ while(!enStack.isEmpty()){ deStack.push(enStack.pop()); } } return deStack.pop(); } } public static void testTwoStackWorkQueue(){ System.out.println("Test TwoStackWorkQueue"); TwoStackWorkQueue queue=new TwoStackWorkQueue (); for(int i=9;i<12;i++){ System.out.println("TwoStackWorkQueue Length:\t"+i); for(int j=0;j { Queue queue1=new Queue (); Queue queue2=new Queue (); public boolean isEmpty(){ return queue1.isEmpty(); } public void push(T data){ queue1.enQueue(data); } public T pop(){ if(isEmpty()){ try { throw new Exception("Empty TwoQueueWorkStack!"); } catch (Exception e) { e.printStackTrace(); } } T data=queue1.deQueue(); while(!queue1.isEmpty()){ queue2.enQueue(data); data=queue1.deQueue(); } Queue tmp=queue1; queue1=queue2; queue2=tmp; return data; } } public static void testTwoQueueWorkStack(){ System.out.println("Test TwoQueueWorkStack"); TwoQueueWorkStack stack=new TwoQueueWorkStack (); for(int i=9;i<12;i++){ System.out.println("TwoQueueWorkStack Length:\t"+i); for(int j=0;j { Object[] stack; int capacity; int top; public Stack(){ capacity=SIZE; stack=new Object[capacity]; top=0; } public Stack(int size){ if(size>SIZE) capacity=size; else capacity=SIZE; stack=new Object[capacity]; top=0; } public boolean isEmpty(){ return top==0; } public void push(T data){ if(top>=capacity){ if(capacity>MAXSIZE){ try { throw new Exception("Stack is so big!"); } catch (Exception e) { e.printStackTrace(); } } capacity=2*capacity; stack=Arrays.copyOf(stack, capacity); } stack[top++]=data; } public T pop(){ T data=peek(); top--; return data; } public T peek(){ if(isEmpty()){ try { throw new Exception("Empty TwoQueueWorkStack!"); } catch (Exception e) { e.printStackTrace(); } } return (T) stack[top-1]; } } public static void testStack(){ System.out.println("Test Stack"); Stack stack=new Stack (); for(int i=9;i<12;i++){ System.out.println("Stack Length:\t"+i); for(int j=0;j { Object[] queue; int capacity; int front; int rear; public Queue(){ capacity=SIZE; queue=new Object[capacity]; front=0; rear=0; } public Queue(int size){ if(size>SIZE) capacity=size; else capacity=SIZE; queue=new Object[capacity]; front=0; rear=0; } public boolean isEmpty(){ return (front==rear); } public void enQueue(T data){ if((rear+1)%capacity==front){ if(capacity>MAXSIZE){ try { throw new Exception("Queue is so big!"); } catch (Exception e) { e.printStackTrace(); } } Object[] queue1=new Object[2*capacity]; int rear1=0; while(front!=rear){ queue1[rear1++]=queue[front]; front=(front+1)%capacity; } rear=rear1; front=0; capacity=2*capacity; queue=queue1; } queue[rear]=data; rear=(rear+1)%capacity; } public T deQueue(){ if(isEmpty()){ try { throw new Exception("Empty Queue!"); } catch (Exception e) { e.printStackTrace(); } } T data=(T) queue[front]; front=(front+1)%capacity; return data; } } public static void testQueue(){ System.out.println("Test Queue"); Queue queue=new Queue (); for(int i=9;i<12;i++){ System.out.println("Queue Length:\t"+i); for(int j=0;j 


下载地址:

http://download.csdn.net/detail/ssuchange/6735647


这篇关于栈和队列操作:栈实现、队列实现、双栈实现队列、双队列实现栈、栈实现O(n)求当前栈最大值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/662320

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

RedHat运维-Linux文本操作基础-AWK进阶

你不用整理,跟着敲一遍,有个印象,然后把它保存到本地,以后要用再去看,如果有了新东西,你自个再添加。这是我参考牛客上的shell编程专项题,只不过换成了问答的方式而已。不用背,就算是我自己亲自敲,我现在好多也记不住。 1. 输出nowcoder.txt文件第5行的内容 2. 输出nowcoder.txt文件第6行的内容 3. 输出nowcoder.txt文件第7行的内容 4. 输出nowcode

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页:

探索蓝牙协议的奥秘:用ESP32实现高质量蓝牙音频传输

蓝牙(Bluetooth)是一种短距离无线通信技术,广泛应用于各种电子设备之间的数据传输。自1994年由爱立信公司首次提出以来,蓝牙技术已经经历了多个版本的更新和改进。本文将详细介绍蓝牙协议,并通过一个具体的项目——使用ESP32实现蓝牙音频传输,来展示蓝牙协议的实际应用及其优点。 蓝牙协议概述 蓝牙协议栈 蓝牙协议栈是蓝牙技术的核心,定义了蓝牙设备之间如何进行通信。蓝牙协议

SQL Server中,always on服务器的相关操作

在SQL Server中,建立了always on服务,可用于数据库的同步备份,当数据库出现问题后,always on服务会自动切换主从服务器。 例如192.168.1.10为主服务器,12为从服务器,当主服务器出现问题后,always on自动将主服务器切换为12,保证数据库正常访问。 对于always on服务器有如下操作: 1、切换主从服务器:假如需要手动切换主从服务器时(如果两个服务

JavaWeb系列二十: jQuery的DOM操作 下

jQuery的DOM操作 CSS-DOM操作多选框案例页面加载完毕触发方法作业布置jQuery获取选中复选框的值jQuery控制checkbox被选中jQuery控制(全选/全不选/反选)jQuery动态添加删除用户 CSS-DOM操作 获取和设置元素的样式属性: css()获取和设置元素透明度: opacity属性获取和设置元素高度, 宽度: height(), widt