zoukankan      html  css  js  c++  java
  • 数据结构(二)_栈

    定义

    栈是一种线性结构,栈是一种后进先出的数据结构

    last in first out(LIFO)

    图解示例

    (来源于网络)

    代码实现

    这里使用之前写的动态数组类

    Stack接口

    /**
     * @author: curry
     * @Date: 2018/8/7
     */
    public interface Stack<E> {
    
        /**
         * 获取栈中元素数量
         *
         * @return
         */
        int getSize();
    
        /**
         * 判断是否为空
         *
         * @return
         */
        boolean isEmpty();
    
        /**
         * 存放元素
         *
         * @param e
         */
        void push(E e);
    
        /**
         * 出栈
         *
         * @return
         */
        E pop();
    
        /**
         * 获取栈顶的值
         *
         * @return
         */
        E peek();
    }
    
    

    ArrayStack

    /**
     * @author: curry
     * @Date: 2018/8/7
     */
    public class ArrayStack<E> implements Stack<E> {
    
        private  Array<E> array;
    
        public ArrayStack(int capacity) {
            array = new Array<>(capacity);
        }
    
        public ArrayStack() {
            array = new Array<>();
        }
    
    
        @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(){
            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上的20题

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

    有效字符串需满足:

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

    示例 1:

    输入: "()"
    输出: true
    示例 2:

    输入: "()[]{}"
    输出: true
    示例 3:

    输入: "(]"
    输出: false
    示例 4:

    输入: "([)]"
    输出: false
    示例 5:

    输入: "{[]}"
    输出: true


    代码实现

    import java.util.Stack;
    
    /**
     * @author: curry
     * @Date: 2018/8/11
     */
    public class Solution {
        public boolean isValid(String s) {
            Stack<Character> stack = new Stack<>();
            for (int i = 0; i < s.length(); i++) {
                char c = s.charAt(i);
                if (c == '(' || c == '{' || c == '[') {
                    stack.push(c);
                } else {
                    if (stack.isEmpty()) {
                        return false;
                    }
    
                    char topChar = stack.pop();
    
                    if (c == ')' && topChar != '(') {
                        return false;
                    }
                    if (c == '}' && topChar != '{') {
                        return false;
                    }
                    if (c == ']' && topChar != '[') {
                        return false;
                    }
    
                }
            }
    
            return stack.isEmpty();
        }
    }
    
    
  • 相关阅读:
    这里有20位程序员关于求职的疑惑,还好也有参考答案
    非科班小白如何逆袭,成功跨考985软件工程?!
    springmvc之RequestMapping中的请求参数和请求头
    springmvc之RequestMapping中的请求方式
    springmvc之RequestMapping注解既可以修饰类也可以修饰方法
    springmvc之第一个springmvc程序
    python之列表推导和生成器表达式
    python之容器序列和扁平序列
    python之利用魔术方法实现自己定义的二维向量
    spring之整合struts2
  • 原文地址:https://www.cnblogs.com/zhenghengbin/p/9461545.html
Copyright © 2011-2022 走看看