算法day25

第一题

394. 字符串解码

解法:模拟栈的完成上述的操作;

分析:

下面以如图的字符串来分析;

首先定义一个数字栈用来存放数字,同时定义一个容器stringbuffer栈,里面用来存放字符串;

1、遇到数字:将这个数字进栈操作到数字栈中;

2、遇到'【'符号,将【符号后面的字符串提取出来,放入到字符串栈中;

3、遇到'】':首先将此时字符串栈顶的字符串拿出来,进行解析,根据数字栈栈顶的数字来重复刚取出来的字符串,最后将解析好的字符串放在字符串栈顶;

4、遇到单独的字符:将这个单独的字符串直接放在字符串栈顶字符的后面;

小细节:如果遇到的数字是非单位数,我们要能够完整的获取到这个多位数的数字;

综上所述,代码如下:

java 复制代码
class Solution {
    public String decodeString(String s) {
        Stack<StringBuffer> st = new Stack<>();
        st.push(new StringBuffer());//先放一个空串
        Stack<Integer> nums = new Stack<>();
        int i = 0,n = s.length();
        char[] s1 = s.toCharArray();
        while(i < n){
            //遇到数字
            if(s1[i] >= '0' && s1[i] <= '9' ){
                int tmp = 0;
                while(i < n && s1[i] >= '0' && s1[i] <= '9' ){
                    tmp = tmp * 10 + (s1[i] - '0');
                    i++;
                }
                nums.push(tmp);
            }
            else if(s1[i] == '['){
                i++;//把后面的字符串提取出来
                StringBuffer tmp = new StringBuffer();
                while(i < n && s1[i] >= 'a' && s1[i] <= 'z' ){
                    tmp.append(s1[i]);
                    i++;
                }
                st.push(tmp);
            }
            else if(s1[i] == ']'){
                //解析字符串
                StringBuffer tmp = st.pop();
                int num = nums.pop();
                while(num-- != 0){
                   st.peek().append(tmp);
                }
                i++;
            }
            else{
                StringBuffer tmp = new StringBuffer();
                while(i < n && s1[i] >= 'a' && s1[i] <= 'z' ){
                    tmp.append(s1[i]);
                    i++;
                }
                st.peek().append(tmp);
            }

        }
        return st.peek().toString();
    }
}

第二题

解法:模拟栈的基本运行逻辑

步骤:

1、让元素一直进栈操作

2、定义指针来指向popped数组的0号位置元素,在进栈后判断栈顶元素是否和出栈元素的指针所指的元素相同,如果相同,则进行出栈操作;如果不同则指针位置向后移动一个位置,接着进行入栈操作;

综上所述,代码如下:

java 复制代码
class Solution {
    public boolean validateStackSequences(int[] pushed, int[] popped) {
        Stack<Integer> st = new Stack<>();
        int i = 0,n = popped.length;
        for(int x : pushed){
            st.push(x);
            while(!st.isEmpty() && st.peek() == popped[i]){
                st.pop();
                i++;
            }
        }
        return i == n;
    }
}

ps:本次的内容就到这里了,如果对你有所帮助的话,就请一键三连哦!!!

相关推荐
123_不打狼9 分钟前
AE(自编码器)与 VAE(变分自编码器)核心区别:原理、目标与应用
深度学习·算法·机器学习·vae
Anastasiozzzz12 分钟前
LeetCode hot100 45 跳跃游戏2
算法·leetcode·游戏
近津薪荼13 分钟前
递归专题(3)——反转链表
数据结构·c++·学习·算法·链表
Tisfy16 分钟前
LeetCode 3013.将数组分成最小总代价的子数组 II:两个堆维护k-1小 + 滑动窗口
算法·leetcode·题解·优先队列··有序集合·滑动窗口
坚持就完事了19 分钟前
Java算法:递归
算法
senijusene21 分钟前
数据结构与算法:完全二叉树和非完全二叉数的各种详细操作以及哈希表的简单应用
数据结构·算法·链表
季明洵1 小时前
反转字符串、反转字符串II、反转字符串中的单词
java·数据结构·算法·leetcode·字符串
2401_841495641 小时前
【Python高级编程】近似串匹配
python·算法·动态规划·字符串·数组·时间复杂度·空间复杂度
lingggggaaaa1 小时前
安全工具篇&魔改二开&CheckSum8算法&Beacon密钥&Stager流量&生成机制
学习·算法·安全·web安全·网络安全·免杀对抗
Python+JAVA+大数据1 小时前
SQL玩出算法竞赛高度!郑凌云数独算法:递归CTE+位运算DFS回溯全解析
数据库·sql·算法·搜索引擎·深度优先·dfs