`
shenyu
  • 浏览: 122589 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

ArrayStack 栈

阅读更多

Array实现的栈结构,功能与LinkedStack一致

编程上略微比LinkedStack复杂

class ArrayStack {
	private Array array = new Array();
	private int pos = -1;
	void push(int value) {
		array.set(value,++pos);
	}

	int pop() {
		assert pos > -1;
		int result = array.get(pos);
		array.truncate(pos--);
		return result;
	}


	boolean isEmpty() {
		return pos == -1;
	}
}
 

 

分享到:
评论

相关推荐

    自定义实现的顺序栈ArrayStack

    利用Java语言实现的,基于数组实现的顺序栈——ArrayStack

    arrayStack.zip

    在这个类中,`ArrayStack`构造函数接受栈的初始容量,并创建一个动态数组。`push`函数在栈未满时将元素添加到栈顶;`pop`函数在栈非空时移除栈顶元素;`peek`函数返回栈顶元素但不移除;`isEmpty`检查栈是否为空;`...

    ArrayStack_TPD

    数组栈是一种基于数组的数据结构,它实现了栈的基本操作,如压入(push)元素和弹出(pop)元素。...ArrayStack_TPD项目可能提供了更具体的实现和示例,进一步研究该项目的源代码将有助于加深对数组栈的理解和实践。

    顺序栈定义

    根据给定的代码片段,我们可以看到一个典型的顺序栈实现,通过定义一个类`ArrayStack`继承自抽象类`Stack`,实现了基本的栈操作:`push`(入栈)、`pop`(出栈)、`top`(获取栈顶元素)和`clear`(清空栈)。...

    栈:如何实现浏览器的前进和后退功能?.pdf

    ### 栈:如何实现浏览器的前进和后退功能? #### 栈的概念 栈是一种非常重要的数据结构,在计算机科学中有着广泛的应用。栈的基本特点是“后进先出”(Last In First Out, LIFO),即最后进入的数据项最先被取出。...

    SkipTheChat#StudyNotes#01数组模拟栈1

    数组模拟栈1.解决思路3.代码代码实现//定义一个 ArrayStack 表示栈// 栈的大小// 数组,数组模拟栈,数据就放在该数组// top表示栈顶,初始

    创建栈的三种形式

    栈是一种特殊的数据结构,它遵循“后进先出”(LIFO)的原则,即最后进入的元素最先出来。在计算机科学中,栈被广泛应用在各种算法和程序设计中,如函数调用、表达式求值、内存管理等。本篇文章将详细探讨创建栈的三...

    使用栈求n个元素的所有排列.pdf

    `ArrayStack` 类是一个数组实现的栈,支持基本的栈操作。 以下是 `ArrayStack` 类的实现代码: ```java public class ArrayStack implements StackADT { private Object[] stack; private int top; private ...

    顺序栈的实现.docx

    以下是一个使用Python实现的简单顺序栈类`ArrayStack`,其中包含上述提到的所有基本操作: ```python class ArrayStack: def __init__(self, capacity): self.capacity = capacity # 栈的容量 self.data = [None...

    在C语言中制造一个栈的方法和思路

    在这个实现中,定义了一个名为ArrayStack的结构体,包含一个固定大小的数组StackData用于存储数据,以及top、bottom和num三个变量来分别表示栈顶位置、栈底位置和栈内元素个数。初始化栈时,分配内存并设置top和...

    数组顺序栈.rar

    数组顺序栈是计算机科学中数据结构的基础概念,它是一种基于数组实现的栈数据结构。栈是一种后进先出(LIFO)的数据结构,通常用于执行递归操作、内存管理、表达式求值等任务。在数组顺序栈中,元素的添加(压栈)和...

    08丨栈:如何实现浏览器的前进和后退功能?1

    浏览器的前进和后退功能是基于数据结构中的“栈”实现的。栈是一种特殊的数据结构,具有后进先出(LIFO,Last In First Out)的特性,即最后放入的数据最先被取出。在这个功能中,浏览器会记录用户访问过的每个页面...

    20151910042-刘鹏-DSA实验06-栈与队列实验1

    在给定的Python代码中,ArrayStack类实现了栈的功能,使用Python列表作为底层存储。ArrayStack类有以下几个主要方法: 1. `__init__(self)`: 构造函数,初始化一个空的栈,通过创建一个空列表`_data`来实现。 2. `_...

    JAVA基于静态数组实现栈的基本原理与用法详解

    ArrayStack类实现了栈接口,使用静态数组实现栈的基本操作。 ```java package Stack; import Array.DynamicArray; public class ArrayStack<E> implements Stack<E> { DynamicArray<E> array; //构造函数,传入栈...

    数组栈的实现(Go)

    数组栈是一种基于数组的数据结构,它实现了栈的基本操作,如入栈(Push)、出栈(Pop)、检查栈是否为空(IsEmpty)以及查看栈顶元素(Top)。在Go语言中,由于其内置的切片(slice)特性,可以方便地创建和操作数组...

    MyArrayStack

    这些测试用例覆盖了栈的各种操作,包括正常情况和异常情况,如空栈操作、满栈操作、连续压栈和弹栈等。通过测试,可以确保MyArrayStack在实际使用中的稳定性和可靠性。 总结,MyArrayStack作为Java实现的栈数据结构...

    Java实现顺序栈原理解析

    Java实现顺序栈原理解析 Java实现顺序栈原理解析是指使用Java语言实现顺序栈的数据结构,顺序栈是一种特殊的线性表,限制了元素的插入和删除只能在线性表的同一端进行。下面将详细介绍Java实现顺序栈原理解析的知识...

    利用栈使用简易计算器(Java实现)

    这里使用了名为ArrayStack的自定义栈类,它基于数组实现。在main方法中,我们定义了一个字符串变量express来存储输入的表达式,以及用于遍历表达式的索引index。 2. 遍历表达式:通过while循环,逐个字符地处理...

    lovXin#book-2#栈和队列1

    * 栈是先进后出* 只能访问栈顶的数据* 基于数组来实现栈的基本操作* 数据项入栈和出栈的时间复杂度均为O(1)public class ArrayStack

Global site tag (gtag.js) - Google Analytics