算法练习笔记——栈的常用方法以及算法练习

简介: 算法练习笔记——栈的常用方法以及算法练习

常用方法介绍


     Stack<Character> characters = new Stack<>();
        //判断栈是否为空
        boolean empty = characters.empty();
        //将a压入栈底,同时也返回a
        Character push = characters.push('a');
        //返回栈顶的元素但是并不会删除它
        Character peek = characters.peek();
        //返回栈顶的元素,并将它删除
        Character pop = characters.pop();
        //在堆栈中搜索a,如果发现了,则返回它相对于栈顶
        //的偏移量。否则,返回-1。
        int search = characters.search('a');
        boolean empty1 = characters.isEmpty();


力扣练习


力扣 20. 有效的括号

d2a72980a4ae408caf8a332b00af6581.png

解法一


class Solution {
    Stack<Character> characters = new Stack<>();
    public boolean isValid(String s) {
       char[] chars = s.toCharArray();
       for(int i=0;i<s.length();i++)
       {
        if(chars[i]=='(') characters.push(')');
        else if(chars[i]=='{') characters.push('}');
        else if(chars[i]=='[') characters.push(']');
        else if(characters.isEmpty()||chars[i]!=characters.pop()) return false;
       }
       return characters.isEmpty();                                                                         
    }
}


思路:

利用到了栈的后入先出的特性

利用左半边的进行判断。如果与之对应就将对应的入栈,下次如果不是左边的,就将栈里面的与之比较相同出栈。


力扣 32. 最长有效括号


ff1038da7b604059872df252b5eeb6e0.png

class Solution {
    public int longestValidParentheses(String s) {
        int maxans=0;
        Stack<Integer> stack = new Stack<>();
        stack.push(-1);
        if(s.length()==0||s.length()==1){
            return 0;
        }
        char[] chars = s.toCharArray();
        for(int i=0;i<s.length();i++){
            if(chars[i]=='(') stack.push(i);
            else{
                stack.pop();
                if(stack.isEmpty()){
                     stack.push(i);
                }
                else{
                     maxans = Math.max(maxans, i-stack.peek());
                }
            }
        }
       return maxans;
    }
}


思路分析:

首先我的第一反应是用栈,当遇到(时,将其入栈,遇到)时将栈顶元素弹出,这样可以实现()的匹对

但是需要的是找出记录出长度和找出最长字符串

我们先定义一个maxans 即最长字符串

接下来我们需要找出最长字符串

我们可以先将字符串转为数组,利用其元素下标,求出最长字符串:

思路就是我们可以将元素下标入栈,记录下最后一个不匹配的元素下标,这样两次做差就可以求出,在每一次都用数学函数找出最大的数据记录

由于第一次没有元素我们可以先将-1入栈

相关文章
|
2月前
|
存储 编解码 算法
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
131 6
|
2月前
|
机器学习/深度学习 算法 调度
14种智能算法优化BP神经网络(14种方法)实现数据预测分类研究(Matlab代码实现)
14种智能算法优化BP神经网络(14种方法)实现数据预测分类研究(Matlab代码实现)
332 0
|
3月前
|
机器学习/深度学习 数据采集 传感器
具有多种最大功率点跟踪(MPPT)方法的光伏发电系统(P&O-增量法-人工神经网络-模糊逻辑控制-粒子群优化)之使用粒子群算法的最大功率点追踪(MPPT)(Simulink仿真实现)
具有多种最大功率点跟踪(MPPT)方法的光伏发电系统(P&O-增量法-人工神经网络-模糊逻辑控制-粒子群优化)之使用粒子群算法的最大功率点追踪(MPPT)(Simulink仿真实现)
310 0
|
1月前
|
机器学习/深度学习 数据采集 负载均衡
结合多种启发式解码方法的混合多目标进化算法,用于解决带工人约束的混合流水车间调度问题(Matlab代码实现)
结合多种启发式解码方法的混合多目标进化算法,用于解决带工人约束的混合流水车间调度问题(Matlab代码实现)
127 0
|
1月前
|
机器学习/深度学习 算法 物联网
基于遗传方法的动态多目标优化算法
基于遗传方法的动态多目标优化算法
|
机器学习/深度学习 算法 数据挖掘
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构
K-means聚类算法是机器学习中常用的一种聚类方法,通过将数据集划分为K个簇来简化数据结构。本文介绍了K-means算法的基本原理,包括初始化、数据点分配与簇中心更新等步骤,以及如何在Python中实现该算法,最后讨论了其优缺点及应用场景。
1153 6
|
7月前
|
机器学习/深度学习 存储 算法
18个常用的强化学习算法整理:从基础方法到高级模型的理论技术与代码实现
本文系统讲解从基本强化学习方法到高级技术(如PPO、A3C、PlaNet等)的实现原理与编码过程,旨在通过理论结合代码的方式,构建对强化学习算法的全面理解。
1935 10
18个常用的强化学习算法整理:从基础方法到高级模型的理论技术与代码实现
|
存储 算法 Java
解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用
在Java中,Set接口以其独特的“无重复”特性脱颖而出。本文通过解析HashSet的工作原理,揭示Set如何利用哈希算法和equals()方法确保元素唯一性,并通过示例代码展示了其“无重复”特性的具体应用。
236 3
|
10月前
|
机器学习/深度学习 人工智能 算法
机器学习算法的优化与改进:提升模型性能的策略与方法
机器学习算法的优化与改进:提升模型性能的策略与方法
1865 13
机器学习算法的优化与改进:提升模型性能的策略与方法
|
11月前
|
算法
【算法】栈
栈相关算法题,供参考,附有链接地址及板书
122 14