栈和队列(优先级队列)

一)删除字符串中所有相邻字符的重复项

1047. 删除字符串中的所有相邻重复项 - 力扣(LeetCode)

算法原理:栈结构+模拟,只是需要遍历所有字符串中的字符,一次存放到栈里面即可,也是可以使用数组来模拟一个栈结构的:
java 复制代码
class Solution {
    public String removeDuplicates(String s) {
        Stack<Character> stack=new Stack<>();
        String ret="";
        for(char ch:s.toCharArray()){
            if(stack.isEmpty()) stack.push(ch);
            else{
                char top=stack.peek();
                if(top==ch){
                    stack.pop();
                }else{
                    stack.push(ch);
                }
            }
        }
        for(char ch:stack){
            ret+=ch;
        }
    return ret;
    }
}
java 复制代码
class Solution {
    public String removeDuplicates(String s) {
        StringBuilder result=new StringBuilder();
        for(char ch:s.toCharArray()){
              if(result.length()==0){
                  result.append(ch);
              }else{
                  if(result.charAt(result.length()-1)==ch){
                      result.deleteCharAt(result.length()-1);
                  }else{
                      result.append(ch);
                  }
              }
        }
    return result.toString();
    }
}

二)比较含退格的字符串

844. 比较含退格的字符串 - 力扣(LeetCode)

算法原理:如果遇到空格,那么直接消掉前面的字符即可,如果当前的第一个字符是#,那么不会抵消前面的任何一个字符,仍然是一个空字符串

java 复制代码
class Solution {
    public String changeStr(String str){
        Stack<Character> stack=new Stack<>();
        String ret="";
        for(char ch:str.toCharArray()){
            if(ch=='#'){
                if(!stack.isEmpty()) stack.pop();
                else continue;
            } 
            else stack.push(ch);
        }
    for(char ch:stack) ret+=ch;
    return ret.toString();
    }
    public boolean backspaceCompare(String s, String t) {
        return changeStr(s).equals(changeStr(t));
    }
}

三)基本运算器(2)

224. 基本计算器 - 力扣(LeetCode)

算法原理:

1)由于乘除运算优于加减运算,因此我们不妨先考虑先进行所有的乘除运算,并将这些乘除运算后的整数值放回到原表达式的位置,然后随后将所有的乘除运算都计算完成之后,随后整个表达式里面的值就是就是相当于是整个一系列整数相加减的值

**2)因此我们可以使用一个栈,保存这些进行乘除运算之后的整数的值,**对于加减号的数字可以直接压入到栈里面,对于乘除号的数字,可以直接和栈顶元素进行计算,并替换栈顶元素作为计算之后的结果

相关推荐
jasligea20 分钟前
构建个人智能助手
开发语言·python·自然语言处理
kokunka24 分钟前
【源码+注释】纯C++小游戏开发之射击小球游戏
开发语言·c++·游戏
C雨后彩虹27 分钟前
CAS与其他并发方案的对比及面试常见问题
java·面试·cas·同步·异步·
_不会dp不改名_1 小时前
leetcode_3010 将数组分成最小总代价的子数组 I
算法·leetcode·职场和发展
云栖梦泽1 小时前
易语言开发从入门到精通:补充篇·网络编程进阶+实用爬虫开发·API集成·代理IP配置·异步请求·防封禁优化
开发语言
java1234_小锋1 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试
铅笔侠_小龙虾2 小时前
Flutter Demo
开发语言·javascript·flutter
2501_944525542 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
计算机学姐2 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法
福大大架构师每日一题2 小时前
ComfyUI v0.11.1正式发布:新增开发者专属节点支持、API节点强化、Python 3.14兼容性更新等全方位优化!
开发语言·python