栈与队列基本操作 Java实现
一、顺序栈
//数组实现顺序栈
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实现的更多相关文章
- 数据结构之栈和队列及其Java实现
栈和队列是数据结构中非常常见和基础的线性表,在某些场合栈和队列使用很多,因此本篇主要介绍栈和队列,并用Java实现基本的栈和队列,同时用栈和队列相互实现. 栈:栈是一种基于“后进先出”策略的线性表.在 ...
- Go实现栈与队列基本操作
@ 目录 一 前言 二 实现栈与队列基本操作 2.1 栈基本操作 2.2 队列基本操作 三 用栈实现队列 3.1 理论 3.2 算法题 3.3 思路 3.4 代码部分 四 用队列实现栈 4.1 理论 ...
- 数据结构 1 线性表详解 链表、 栈 、 队列 结合JAVA 详解
前言 其实在学习数据结构之前,我也是从来都没了解过这门课,但是随着工作的慢慢深入,之前学习的东西实在是不够用,并且太皮毛了.太浅,只是懂得一些浅层的,我知道这个东西怎么用,但是要优化.或者是解析,就不 ...
- 算法_栈与队列的Java链表实现
链表是一个递归的数据结构,它或者为null,或者是指向一个结点的引用,该结点含有一个泛型的元素和指向另一个链表的引用.可以用一个内部类来定义节点的抽象数据类型: private class Node ...
- 剑指Offer-5.用两个栈实现队列(C++/Java)
题目: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 分析: 栈的特点是先进后出,队列的特点则是先进先出. 题目要求我们用两个栈来实现一个队列,栈和队列都有入栈 ...
- 两个队列实现栈&两个栈实现队列(JAVA)
1,两个栈实现队列 题目描述 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 思路:栈的特点时先进后出,队列的特点是先进先出. 若此时有两个队列stack1,st ...
- 剑指offer第二版面试题8:用两个栈实现队列(JAVA版)
题目:用两个栈实现一个队列.队列的声明如下,请实现它的两个函数appendTail和deletedHead,分别完成在队列尾部插入节点和在队列头部删除节点的功能. 分析: 我们通过一个具体的例子来分析 ...
- 剑指offer 计划1(栈与队列)---java
1.1.题目1 剑指 Offer 09. 用两个栈实现队列 1.2.解法 解法如题目所说.定义两个栈.这里假设第一个栈为a,第二个栈为b. 实现两个函数增加尾和删除头. 增加即直接push入第一个栈. ...
- 栈和队列的Java实现
一. 栈 1.概念 栈是一种特殊的线性表,它只能在栈顶(top)进行插入(push)和删除(pop)操作. 栈的常用操作: 入栈(push):向栈顶插入元素 出栈(pop):从栈顶删除元素 访问栈顶 ...
随机推荐
- [Luogu] 魔法树
https://www.luogu.org/problemnew/show/P3833 树链剖分 + 线段树 为啥会RE?? 不解 #include <iostream> #include ...
- [转载]作为理工科学生,我们为什么要练就好的文笔?我们需要发blog来记录学习历程?
文/JoeyChen 工程师该怎样才能突破自己的能力瓶颈?写 blog! 工程师该怎样精进自己在职涯上所需要的能力?写 blog! 工程师该怎样才能保持学习与成长的动能?写 blog! 工程师该怎样才 ...
- c str to float
#include <wchar.h> int main () { wchar_t szOrbits[] = L"365.24 29.53"; wchar_t * pEn ...
- hadoop HA+Federation(高可用联邦)搭建配置(一)
hadoop HA+Federation(高可用联邦)搭建配置(一) 标签(空格分隔): 未分类 介绍 hadoop 集群一共有4种部署模式,详见<hadoop 生态圈介绍>. HA联邦模 ...
- Linux Redis的性能展示
我们可以通过redis-cli 连接上redis ,例如 : redis-cli -h 127.0.0.1 -p 6379 连接上redis,然后通过INFO查看redis的一些信息.我们可以查看一些 ...
- Tomcat配置 https SSL证书
HTTP与HTTPS的区别:HTTP协议传输的数据都是未加密的,也就是明文的,因此使用HTTP协议传输隐私信息非常不安全,为了保证这些隐私数据能加密传输,于是网景公司设计了SSL(Secure Soc ...
- cookies ,session,localstorage讲解
一 .cookie (1)简介 因为HTTP协议是无状态的,服务器不知道用户上一次做了什么,这严重阻碍了交互式Web应用程序的实现.在典型的网上购物场景中,用户浏览了几个页面,买了一盒饼干和两饮料.最 ...
- javafx随手记录
javafx的webview嵌套网页的时候可能会遇到一些需要允许跨域访问(禁止同源策略)的页面 那么我们在初始化的代码前加上以下代码即可 System.setProperty("sun.ne ...
- flutter中的生命周期函数
前言:生命周期是一个组件加载到卸载的整个周期,熟悉生命周期可以让我们在合适的时机做该做的事情,flutter中的State生命周期和android以及React Native的生命周期类似. 先看一张 ...
- mysql中的utf8mb4、utf8mb4_unicode_ci、utf8mb4_general_ci的关系
mysql中的utf8mb4.utf8mb4_unicode_ci.utf8mb4_general_ci的关系 一.总结 一句话总结: utf8mb4是utf8的超集并完全兼容utf8,能够用四个字节 ...