博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java Stack栈的实现
阅读量:3753 次
发布时间:2019-05-22

本文共 1129 字,大约阅读时间需要 3 分钟。

栈作为一种数据结构,是一种只能在一端进行插入和删除操作的特殊线性表。它按照后进先出的原则存储数据,先进入的数据被压入栈底,最后的数据在栈顶,需要读数据的时候从栈顶开始弹出数据(最后一个数据被第一个读出来)。栈具有记忆作用,对栈的插入与删除操作中,不需要改变栈底指针。栈是允许在同一端进行插入和删除操作的特殊线性表。允许进行插入和删除操作的一端称为栈顶(top),另一端为栈底(bottom);栈底固定,而栈顶浮动;栈中元素个数为零时称为空栈。插入一般称为进栈(PUSH),删除则称为退栈(POP)。栈也称为后进先出表。

在这里插入图片描述

堆栈只定义了默认构造函数,用来创建一个空栈。 堆栈除了包括由Vector定义的所有方法,也定义了自己的一些方法。

Stack()除了由Vector定义的所有方法,自己也定义了一些方法:

boolean empty() //测试堆栈是否为空。Object peek( )//查看堆栈顶部的对象,但不从堆栈中移除它。Object pop( )//移除堆栈顶部的对象,并作为此函数的值返回该对象。Object push(Object element)//把项压入堆栈顶部。int search(Object element)//返回对象在堆栈中的位置,以 1 为基数。

如何自己实现一个栈呢?

其实用数据就能实现:

public class stack {    private int maxSize;//指定栈的大小    private int top;//栈顶    private char[] arr;//存储数组及类型    public stack(int size) {//实现方法        maxSize = size;        top = -1;        arr = new char[maxSize];    }    public void push(char value) { // 压入数据        arr[++top] = value;    }    public char pop() { // 弹出数据        return arr[top--];    }    public char peek() { // 访问栈顶元素        return arr[top];    }    public boolean isFull() { // 栈是否满了        return maxSize - 1 == top;    }    public boolean isEmpty() { // 栈是否为空        return top == -1;    }

转载地址:http://qtssn.baihongyu.com/

你可能感兴趣的文章
String 类
查看>>
什么是接口
查看>>
Java高级篇之进程
查看>>
类加载机制
查看>>
了解jdk1.8版本一些新的特性
查看>>
Java高级篇之网络通讯
查看>>
浅谈篇之线程池
查看>>
Lambda 表达式
查看>>
字符串函数MySQL
查看>>
8个SQL讲解优化
查看>>
MySQL实战续(二)
查看>>
安装Elastic和kibana
查看>>
什么是搜索
查看>>
全文检索工具elasticsearch
查看>>
Vue之条件渲染实战
查看>>
Vue之侦听属性
查看>>
求职指南(1)
查看>>
MySQL day11
查看>>
MySQL day12
查看>>
JSONP原理
查看>>