一、顺序栈

//数组实现顺序栈
public class OrderStack {
private String[] elem;
private int top;
OrderStack(int k) {
elem = new String[k];
top = -1;
}
//判满
boolean isFull() {
return top == (elem.length - 1);
}
//判空
boolean isEmpty() {
return top == -1;
}
//进栈
boolean push(String s) {
if(isFull()) {
return false;
}
elem[++top] = s;
return true;
}
//出栈
String pop() {
if(isEmpty()) {
System.out.println("Empty stack");
return null;
}else {
return elem[top--];
}
}
//获取栈顶元素
String getTop() {
if(isEmpty()) {
System.out.println("Empty stack");
return null;
}else {
return elem[top];
}
} }

二、链栈

存储结构

public class LinkNode {
int i;
LinkNode next;
LinkNode(int i) {
this.i = i;
}
public String toString() {
return String.valueOf(i);
}
}

 链栈实现

//链表存储实现
public class LinkStack {
private LinkNode top;
LinkStack() {
top = new LinkNode(-1);
}
boolean isEmpty() {
return top.next ==null;
}
//头插法方便出栈
LinkNode push(LinkNode temp) {
if(temp == null) {
System.out.println("null pointer");
}
temp.next = top.next;
top.next = temp;
return temp;
}
LinkNode pop() {
LinkNode temp = null;
if(isEmpty()) {
System.out.println("empty");
return null;
}
temp = top.next;
top.next = temp.next;
return temp;
}
LinkNode getTop() {
return top.next;
}
}

三、队列

存储结构

public class LinkNode {
int i;
LinkNode next;
LinkNode(int i) {
this.i = i;
}
public String toString() {
return String.valueOf(i);
}
}

 链队列

public class MyQueue {
private LinkNode front;
private LinkNode rear;
MyQueue() {
front = new LinkNode(-1);
rear = front;
}
boolean isEmpty() {
return front == rear;
}
LinkNode enterQueue(LinkNode temp) {
rear.next = temp;
rear = temp;
return temp;
}
LinkNode deleteQueue() {
if(isEmpty()) {
System.out.println("Empty");
}
LinkNode temp = front.next;
if(front.next == rear) {
front.next = rear.next;
rear = front;
}
front.next = temp.next;
temp.next = null;
return temp;
}
}

 循环队列

//数组实现的循环队列
//采用不损失空间的方式实现
public class CirQueue {
private String[] elem;
private int front;
private int rear;
//入队flag赋1值,出队flag赋0值
private int flag = 0;
CirQueue(int k) {
elem = new String[k];
front = 0;
rear = 0;
}
boolean isFull() {
return flag == 1 && rear == front;
}
boolean isEmpty() {
return flag == 0 && rear == front;
}
String enter(String temp) {
if(isFull()) {
System.out.println("Full");
}else {
elem[rear] = temp;
rear = (rear + 1) % elem.length;
flag = 1;
}
return temp;
}
String delete() {
String temp = null;
if(isEmpty()) {
System.out.println("Empty");
}else {
temp = elem[front];
front = (front + 1)%elem.length;
flag = 0;
}
return temp;
}
}

这里使用了一个编程的小技巧,将操作打上了记号。

栈与队列基本操作 Java实现的更多相关文章

  1. 数据结构之栈和队列及其Java实现

    栈和队列是数据结构中非常常见和基础的线性表,在某些场合栈和队列使用很多,因此本篇主要介绍栈和队列,并用Java实现基本的栈和队列,同时用栈和队列相互实现. 栈:栈是一种基于“后进先出”策略的线性表.在 ...

  2. Go实现栈与队列基本操作

    @ 目录 一 前言 二 实现栈与队列基本操作 2.1 栈基本操作 2.2 队列基本操作 三 用栈实现队列 3.1 理论 3.2 算法题 3.3 思路 3.4 代码部分 四 用队列实现栈 4.1 理论 ...

  3. 数据结构 1 线性表详解 链表、 栈 、 队列 结合JAVA 详解

    前言 其实在学习数据结构之前,我也是从来都没了解过这门课,但是随着工作的慢慢深入,之前学习的东西实在是不够用,并且太皮毛了.太浅,只是懂得一些浅层的,我知道这个东西怎么用,但是要优化.或者是解析,就不 ...

  4. 算法_栈与队列的Java链表实现

    链表是一个递归的数据结构,它或者为null,或者是指向一个结点的引用,该结点含有一个泛型的元素和指向另一个链表的引用.可以用一个内部类来定义节点的抽象数据类型: private class Node ...

  5. 剑指Offer-5.用两个栈实现队列(C++/Java)

    题目: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 分析: 栈的特点是先进后出,队列的特点则是先进先出. 题目要求我们用两个栈来实现一个队列,栈和队列都有入栈 ...

  6. 两个队列实现栈&两个栈实现队列(JAVA)

    1,两个栈实现队列 题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 思路:栈的特点时先进后出,队列的特点是先进先出. 若此时有两个队列stack1,st ...

  7. 剑指offer第二版面试题8:用两个栈实现队列(JAVA版)

    题目:用两个栈实现一个队列.队列的声明如下,请实现它的两个函数appendTail和deletedHead,分别完成在队列尾部插入节点和在队列头部删除节点的功能. 分析: 我们通过一个具体的例子来分析 ...

  8. 剑指offer 计划1(栈与队列)---java

    1.1.题目1 剑指 Offer 09. 用两个栈实现队列 1.2.解法 解法如题目所说.定义两个栈.这里假设第一个栈为a,第二个栈为b. 实现两个函数增加尾和删除头. 增加即直接push入第一个栈. ...

  9. 栈和队列的Java实现

    一.  栈 1.概念 栈是一种特殊的线性表,它只能在栈顶(top)进行插入(push)和删除(pop)操作. 栈的常用操作: 入栈(push):向栈顶插入元素 出栈(pop):从栈顶删除元素 访问栈顶 ...

随机推荐

  1. jQuery系列(六):jQuery的文档操作

    1.插入操作 (1) 语法: 父元素.append(子元素) 解释:追加某元素,在父元素中添加新的子元素.子元素可以为:stirng | element(js对象) | jquery元素 let ol ...

  2. Friend-Graph (HDU 6152)2017中国大学生程序设计竞赛 - 网络选拔赛

    Problem Description It is well known that small groups are not conducive of the development of a tea ...

  3. Vue 使用百度地图组件

    npm 安装 npm install vue-baidu-map --save组件官网地址 https://dafrok.github.io/vue-baidu-map/#/

  4. 预处理、const、static与sizeof-sizeof与strlen有哪些区别

    1:它们的区别如下: (1)sizeof是操作符,strlen是函数. (2)sizeof操作符的结果类型是size_t,它在头文件中typedef为unsignedint类型,该类型保证能容纳实现所 ...

  5. 使用docker部署mysql主从复制集群

    一.环境搭建 虚拟机环境:centos7 IP: 启动3个容器,一个是master,端口是3307,另外两个是slaver,端口是3308和3309 docker pull mysql:5.7 doc ...

  6. Leetcode题目121.买卖股票的最佳时机(简单)

    题目描述: 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. 如果你最多只允许完成一笔交易(即买入和卖出一支股票),设计一个算法来计算你所能获取的最大利润. 注意你不能在买入股票前卖出 ...

  7. 字符串暴力枚举子序列求LCS

    题意: 求n个串里的LCS,长度相同时按照字典序排序 solution: 断环为链,二进制枚举子序列,压入vector,按照字典序排序 把出现次数为n的,压入第二个vector 输出最长的第二个vec ...

  8. ArcGIS Python查看geodatabase(.gdb)版本

    代码:10.0不能运行 import arcpy desc = arcpy.Describe(r'C:\Users\dell\Documents\ArcGIS\default.gdb') print ...

  9. redis-Sentinel持续高可用

    自动故障转移机制 redis目前只支持主从复制备份(不支持主主复制),当主redis挂了,从redis只能提供读服务,无法提供写服务.所以,还得想办法,当主redis挂了,让从redis升级成为主re ...

  10. redis数据类型及订阅操作

    Redis数据类型详解 Redis键/值介绍 Redis key值是二进制安全的,这意味着可以用任何二进制序列作为key值,从形如“foo”的简单字符串到一个JPG文件的内容都可以.空字符串也是有效k ...