美文网首页
线性结构--栈

线性结构--栈

作者: 二妹是只猫 | 来源:发表于2019-06-26 13:14 被阅读0次
特点:
  • 栈是一种线性结构
  • 相比数组,栈对应的操作是数组的子集
  • 只能从一端添加元素,也只能从同一端取出元素
  • 是一种后进先出的数据结构(Last in First Our)
  • 这一端称为栈顶
无处不在的应用:

由于后进先出这种特殊的数据结构,使得栈的应用极其广泛。日常在ide中我们的编辑操作--撤销(Undo)和括号匹配、操作系统--系统调用栈等等。

实现(stack继承自Vector,而Vector是由数组实现,接下来就通过数组来手写一个stack)

接口:Stack

public interface Stack<E> {
    //获取size
    int getSize();
    //是否为空
    boolean isEmpty();
    //添加到栈中
    void push(E e);
    //从栈顶取出
    E pop();
    //查看栈顶
    E peek();
}

实现:ArrayStack(下面的数组Array是上一篇手写的,在这里也可以验证下实现效果)

public class ArrayStack<E> implements Stack<E> {
    
    private Array array;

    public ArrayStack(int capacity){
        array = new Array(capacity);
    }

    public ArrayStack(){
        this(10);
    }
    @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 (E) array.removeLast();
    }

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

    @Override
    public String toString(){
        StringBuilder res = new StringBuilder();
        res.append("Stack: ");
        res.append('[');
        for(int i = 0 ; i < array.getSize() ; i ++){
            res.append(array.get(i));
            if(i != array.getSize() - 1)
                res.append(", ");
        }
        res.append("] top");
        return res.toString();
    }
}
leetcode真题检验--括号匹配

题目:给定一个只包括 '(',')','{','}','[',']' 的字符串,判断字符串是否有效。

有效字符串需满足:

左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
注意空字符串可被认为是有效字符串。

解答:

public class Solution {
    public boolean isValid(String s)  {
        ArrayStack<Character> characterStack = new ArrayStack<Character>();
        for (int i = 0; i < s.length(); i++) {
            Character c = s.charAt(i);
            if ('('==(c) || '['==(c) || '{'==(c)) {
                characterStack.push(c);
            } else {
                if (characterStack.isEmpty()) {
                    return false;
                }
                Character top = characterStack.pop();
                if ('('==(top) && ')'!=(c)) {
                    return false;
                }
                if ('['==(top) && ']'!=(c)) {
                    return false;
                }
                if ('{'==(top) && '}'!=(c)) {
                    return false;
                }
            }
        }
        return characterStack.isEmpty();
    }
}

相关文章

  • python数据结构教程 Day3

    本节重点: 线性结构介绍 栈结构介绍 栈结构ADT实现 栈在问题中的应用 一、线性结构 定义: 线性结构是一种有序...

  • 栈的顺序存储结构

    栈的顺序存储结构 栈是一种重要的线性结构,可以这样讲,栈是线性表的一种具体形式。 栈这种后进先出的数据结构应用是非...

  • 3-玩转数据结构-栈和队列

    我们会介绍两个全新的线性数据结构,栈与队列。 栈Stack 栈也是一种线性结构;相比数组,栈对应的操作是数组的子集...

  • 栈和队列

    栈和队列是两种应用非常广泛的数据结构,它们都来自线性表数据结构,都是“操作受限”的线性表。 栈 栈(Stack):...

  • 数据结构之栈

    栈和队列都属于线性数据的逻辑存储结构 概念 栈(stack)是一种线性数据结构,栈中的元素只能先入后出(First...

  • 线性结构--栈

    特点: 栈是一种线性结构 相比数组,栈对应的操作是数组的子集 只能从一端添加元素,也只能从同一端取出元素 是一种后...

  • 线性结构:栈

    思路 栈是一种先进后出(First In Last Out, FILO)的数据结构。相对上一篇的数组,它只能在最后...

  • 数据结构(线性结构 栈与队列)

    栈与队列都是特殊的线性表,它们也是线性结构。用户可以采用顺序存储结构和链式存储结构两种方式来存储。栈和队列结构是各...

  • 04栈和队列(特殊的线性表)

    1.栈 1.栈 栈:栈是限定仅在表尾进行插入和删除操作的特殊的线性表。线性表按照存储结构分有顺序存储结构实现的顺序...

  • 数据结构与算法掌握这些就够了

    数据结构 线性结构数组、链表、栈、队列 非线性多维数组、树、图 1. 栈 后进先出,可以处理递归调用实际应用:字符...

网友评论

      本文标题:线性结构--栈

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