zoukankan      html  css  js  c++  java
  • 2.数据结构--栈

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

    1.栈的应用:

    (1)撤销--编辑器

    (2)程序调用的系统栈--操作系统

    (3)括号匹配--编译器(https://leetcode-cn.com/problems/valid-parentheses/description/)

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

    有效字符串需满足:

    1. 左括号必须用相同类型的右括号闭合。
    2. 左括号必须以正确的顺序闭合。

    注意空字符串可被认为是有效字符串。

    import java.util.Stack;
    
    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();
        }
    }

    调用实例:

    public class Main {
        public static void main(String[] args) {
            Solution so = new Solution();
            String s = "(){]{}";
            boolean res = so.isValid(s);
            System.out.println(res);    //false
        }
    }

    2.栈的基本实现

    public interface Stack<E> {
        int getSize();
        boolean isEmpty();
        void push(E e);
        E pop();
        E peek();
    }

    实现接口

    public class ArrayStack<E>  implements Stack<E>{
        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();
        }
    
        public int getCapacity(){
            return array.getCapacity();
        }
    
        @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();
        }
    }

    调用实例:

    public class Main {
        public static void main(String[] args) {
            ArrayStack<Integer> stack = new ArrayStack<>();
            for(int i = 0;i < 5;i ++){
                stack.push(i);
                System.out.println(stack);
            }
            stack.pop();
            System.out.println(stack);
    //        Stack:[0] top
    //        Stack:[0,1] top
    //        Stack:[0,1,2] top
    //        Stack:[0,1,2,3] top
    //        Stack:[0,1,2,3,4] top
    //        Stack:[0,1,2,3] top
        }
    }

     3.栈的复杂度分析

  • 相关阅读:
    linux 文件系统(inode和block)
    vue状态管理vuex从浅入深详细讲解
    小白都能看懂的vue中各种通信传值方式,附带详细代码
    CSS3移动端vw+rem不依赖JS实现响应式布局
    JavaScript原生封装ajax请求和Jquery中的ajax请求
    永久解决Sublime包管理package control 打开install package报错 There are no packages available for installation
    从GitLab上创建分支本地拉取项目和提交项目详解
    前端路由的两种实现方式,内附详细代码
    几个例子理解浅拷贝和深拷贝
    讲解JavaScript中对闭包的理解
  • 原文地址:https://www.cnblogs.com/zouke1220/p/9490491.html
Copyright © 2011-2022 走看看