美文网首页
实现栈_基于数组

实现栈_基于数组

作者: 苏州城外无故人 | 来源:发表于2019-04-15 19:10 被阅读0次

基于动态数组实现栈
声明栈的接口

package com.company.stack;

public interface Stack<E> {

    int getSize();
    boolean isEmpty();
    void push(E e);
    E pop();
    E peek();
}

实现类及测试

package com.company.stack;

import com.company.Array;

/**
 * @program: Array
 * @description: 动态数组实现栈
 * @author: Gu
 * @create: 2019-04-14 19:58
 **/

public class ArrayStack<E> implements Stack<E>{

    private Array<E> array;

    private ArrayStack() {
        array = new Array<>();
    }

    private ArrayStack(int capacity) {
        array = new Array<>(capacity);
    }

    public int getCapacity() {
        return array.length();
    }
    @Override
    public int getSize() {
        return array.getSize();
    }

    @Override
    public boolean isEmpty() {
        return array.isEmpty();
    }

    @Override
    public void push(E e) {
        array.addLast(e);
    }

    @Override
    public E pop() {
        return array.removeLast();
    }

    @Override
    public E peek() {
        return array.getLast();
    }

    @Override
    public String toString() {
        StringBuffer stringBuffer = new StringBuffer();
        stringBuffer.append(String.format("栈的size:%d, capaticy: %d \n", getSize(), getCapacity()));
        stringBuffer.append("[");
        for (int i = 0; i < getSize(); i++) {
            stringBuffer.append(array.get(i));
            if (i == getSize() - 1) {
                stringBuffer.append("] top");
                break;
            }
            stringBuffer.append(",");
        }
        return stringBuffer.toString();
    }

    public static void main(String[] args) {
        ArrayStack<Integer> arrayStack = new ArrayStack<>();
        for (int i = 0; i < 10; i++) {
            arrayStack.push(i);
        }
        System.out.println(arrayStack.toString());
        System.out.println(arrayStack.pop());
        System.out.println(arrayStack.peek());

    }
}

相关文章

  • 实现栈_基于数组

    基于动态数组实现栈声明栈的接口 实现类及测试

  • 基于动态数组的实现 Java实现 基于链表的栈的实现 Java实现

  • 数据结构之栈和队列

    栈 栈 Stack: 栈是一种线性结构 相比数组,栈对应的操作是数组的子集,所以我们完全可以基于动态数组去实现它 ...

  • 栈实现

    栈是先进先出数据结构。下面基于数组,实现栈结构。 Stack继承Vector elementData:Object...

  • 数据结构——栈和队列

    用数组实现栈和队列 用栈实现队列 用队列实现栈 栈和队列的经典算法题最小间距栈宠物收养所 数组实现栈和队列 用数组...

  • 一、定义 下压栈(简称栈)是一种基于后进先出(LIFO)策略的集合类型。 二、API 三、实现 3.1 数组实现 ...

  • 数据结构java描述

    接口 栈 队列 集合 并查集 映射 数组 链表 栈 数组实现 链表实现 队列 数组实现 链表实现 二分搜索树 集合...

  • 栈的实现(基于动态数组)

    先定义一个接口 再定义一个栈的实现类,实现上述接口

  • 数据结构

    用数组实现栈

  • [算法题] 使用数组实现栈和队列

    1. 使用数组实现栈 2. 使用数组实现队列

网友评论

      本文标题:实现栈_基于数组

      本文链接:https://www.haomeiwen.com/subject/glppwqtx.html