栈和队列操作:栈实现、队列实现、双栈实现队列、双队列实现栈、栈实现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

相关文章

pandas中位数填充空值的实现示例

《pandas中位数填充空值的实现示例》中位数填充是一种简单而有效的方法,用于填充数据集中缺失的值,本文就来介绍一下pandas中位数填充空值的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是中位数填充?为什么选择中位数填充?示例数据结果分析完整代码总结在数据分析和机器学习过程中,处理缺失数

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

Java对象转换的实现方式汇总

《Java对象转换的实现方式汇总》:本文主要介绍Java对象转换的多种实现方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java对象转换的多种实现方式1. 手动映射(Manual Mapping)2. Builder模式3. 工具类辅助映

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py