首页 > 其他分享 >leetcode-394.字符串解码

leetcode-394.字符串解码

时间:2022-10-11 13:44:27浏览次数:86  
标签:count StringBuilder 解码 pop leetcode 394 sb new stack

394. 字符串解码

public String decodeString(String s) {
        Stack<Character> stack = new Stack<>();
        for(char c : s.toCharArray()){
            if(c != ']'){//如果不是']'把所有字符加入
                stack.push(c);
            }else{// 如果遇到']'说明 c[letter以及全部输入到栈中了
                StringBuilder sb = new StringBuilder();
                while(!stack.isEmpty() && Character.isLetter(stack.peek())){//如果遇到了']',则把栈里所有 字符 都插入到sb中
                    sb.insert(0, stack.pop());
                }
                String letters = sb.toString();//sb转成字符串
                
                stack.pop(); // 去除'['
                
                sb = new StringBuilder();//重置StringBuilder准备记录数字
                while(!stack.isEmpty() && Character.isDigit(stack.peek())){//如果遇到了数字,则记录数字,别忘了数字有位数,个位十位百位千位,不只是一位数字,所有数字都加入到sb中
                    sb.insert(0, stack.pop());
                }
                int count = Integer.valueOf(sb.toString());//把字符串转换为整数

                //根据count次数,拆除[],再塞入到栈里去,由于stack只能放char字符,所以这里都拆成字符一个个放进去
                while(count != 0){
                    for(char r : letters.toCharArray()){
                        stack.push(r);
                    }
                    count --;
                }
            }
        }
        StringBuilder res = new StringBuilder();
        //取出栈中所有字符
        while(!stack.isEmpty()){
            res.insert(0, stack.pop());
        }
        return res.toString();
    }

标签:count,StringBuilder,解码,pop,leetcode,394,sb,new,stack
From: https://www.cnblogs.com/phonk/p/16778922.html

相关文章

  • leetcode 785. Is Graph Bipartite判断二分图 (中等)
    一、题目大意存在一个无向图,图中有n个节点。其中每个节点都有一个介于0到n-1之间的唯一编号。给你一个二维数组graph,其中graph[u]是一个节点数组,由节点u......
  • Leetcode 33 -- 二分查找&&归约思想
    题目描述搜索旋转排序数组思路思路来源一个清晰的思路:这道题和平常二分法查找的不同就在于,把一个有序递增的数组分成了,两个递增的数组,我们需要做的就是判断这个......
  • leetcode-128. 最长连续序列
    128.最长连续序列首先去重,直接把数组装入set集合即可然后,设集合中的某个数为a。遍历集合set假如这个集合中,存在a-1,说明a不是一个序列的起始值,跳过如果不存在a......
  • [LeetCode] 1328. Break a Palindrome
    GivenapalindromicstringoflowercaseEnglishletters palindrome,replace exactlyone characterwithanylowercaseEnglishlettersothattheresultingst......
  • LeetCode算法笔记 350. 两个数组的交集 II
    importjunit.framework.TestCase;importjava.util.Arrays;importjava.util.HashMap;publicclassLeetCode03extendsTestCase{/***350.两个数组......
  • Leetcode 11 -- 贪心
    题目描述最小字典许思路思路来源由于t中的字符后进先出,可以使用一个暂存栈来保存s删除的第一个字符入栈很简单,初始状态下,栈为空,我们可以直接入栈,因此,每次遍历我们......
  • leetCode 27. Remove Element
    [27.RemoveElement][(https://leetcode.cn/problems/remove-element/)思路数组在内存中是连续的,根据此题要求不能删除,而是覆盖暴力解法此题暴力解法是两层for......
  • leetcode-287. 寻找重复数-数组构成的链表
    287.寻找重复数由题中数字都在[1,n]范围内(包括1和n),可知至少存在一个重复的整数。维护一个映射关系f(n)=index->num,其中数组的下标index,数字为num当一......
  • leetcode349.两个数组的交集
    1.题目描述给定两个数组nums1和nums2,返回它们的交集。输出结果中的每个元素一定是唯一的。我们可以不考虑输出结果的顺序。2.示例示例1:输入:nums1=[1,2,2,......
  • leetcode 236. Lowest Common Ancestor of a Binary Tree 二叉树的最近公共祖先(中等)
    一、题目大意给定一个二叉树,找到该树中两个指定节点的最近公共祖先。百度百科中最近公共祖先的定义为:“对于有根树T的两个节点p、q,最近公共祖先表示为一个节点x,满......