【LeetCode笔记】394. 字符串解码(Java、递归、栈)

文章目录

  • 题目描述
  • 思路 & 代码
      • 更新版

题目描述

  • 开心!!独立思考字符串题,还AC了,成就感满满 XD
  • 难点应该是在于嵌套括号,那么这里实际上还要考虑到一个类似于括号匹配的事情
  • 谈到括号,那么大概率用到
    在这里插入图片描述

思路 & 代码

  • 当前栈帧,只解决一层的括号,如果内嵌了括号,那么把当前层内的整个字符串放入下一层进行递归处理。
  • 举个例子:3[a2[c]],那么把 a2[c] 放入下层栈帧处理,返回成 3[acc],再继续变成 accaccacc
  • 栈的作用:得到放入下层的字符串(最外层括号结束判断)
class Solution {// 递归 + 栈// 组成[]则直接拆,否则进入下一层public String decodeString(String s) {StringBuffer ans = new StringBuffer();Stack<Character> leftStack = new Stack<>();int nowNum = 0;for(int i = 0; i < s.length(); i++){// 遇到数字了if(s.charAt(i) >= '0' && s.charAt(i) <= '9'){int numJ = i + 1;nowNum = s.charAt(i) - '0';while(s.charAt(numJ) != '['){nowNum *= 10;nowNum += s.charAt(numJ) - '0';numJ++;}// 再下一个肯定是 '['for(int j = numJ; ; j++){if(s.charAt(j) == '['){leftStack.push(s.charAt(i + 1));}else if(s.charAt(j) == ']'){leftStack.pop();// 找到可拆组合,进入下一层if(leftStack.isEmpty()){String temp = decodeString(s.substring(numJ + 1, j));for(int k = 0; k < nowNum; k++){ans.append(temp);}// 结束本次递归i = j;break;}}}}else{ans.append(s.charAt(i));}}return ans.toString();}
}
  • 代码注意点:
  1. 数字不一定是个位数,还要进行一个字符串转数字处理
  2. 用 StringBuffer,最后返回 toString() 比较好
  3. 循环比较多,而且每个栈帧本质上都是一次循环,所以要小心死循环等情况。

更新版

class Solution {public String decodeString(String s) {Deque<Integer> stack = new ArrayDeque<>();char[] arr = s.toCharArray();StringBuilder sb = new StringBuilder();for(int i = 0; i < arr.length; i++) {if(arr[i] >= '0' && arr[i] <= '9') {int num = 0;while(arr[i] >= '0' && arr[i] <= '9') {num *= 10;num += arr[i++] - '0';}for(int j = i; ; j++) {if(arr[j] == '[') {stack.push(j);}else if(arr[j] == ']') {stack.pop();if(stack.isEmpty()) {String temp = decodeString(s.substring(i + 1, j));for(int k = 0; k < num; k++) {sb.append(temp);}i = j;break;}}}}else {sb.append(arr[i]);}}return sb.toString();}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/504487.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ad19pcb设置恢复默认_苹果手机便签怎么恢复系统默认的内容分割线?

苹果手机上虽然没有系统自带的便签app&#xff0c;但是可以添加使用第三方的敬业签。敬业签&#xff0c;是一款支持备忘内容云端同步并提醒的跨平台(Windows电脑﹑安卓手机﹑苹果iPhone手机﹑iPad﹑苹果电脑Mac端以及网页Web端)桌面便签软件&#xff0c;备忘效果更好&#xff0…

【LeetCode笔记】剑指 Offer 56 . 数组中数字出现的次数(Java、位运算)

文章目录题目描述思路 & 代码题目描述 比 leetcode 136要难点注意&#xff1a;空间复杂度要求O(1)&#xff0c;否则用哈希表直接秒杀啦。昨天的笔试&#xff0c;还有刷的面经都有这道题。。。今天赶紧补补 思路 & 代码 相对于 leetcode 136&#xff0c;这边多了个分…

电脑计算器的快捷键_牛!这份金蝶财务软件使用手册+超全快捷键汇总送你,财务收好...

金蝶财务软件想要使用的好是有技巧的&#xff01;快捷键简易汇总&#xff1a;快捷键详细说明1、凭证处理①、摘要栏两种快速复制摘要的功能&#xff0c;在下一行中按“..”可复制上一条摘要&#xff0c;按“//”可复制第一条摘要。同时&#xff0c;系统还设计了摘要库&#xff…

【LeetCode笔记】415. 字符串相加(Java、字符串)

题目描述 不能直接把字符串转换成整数&#xff08;会溢出&#xff09;面试被问过&#xff0c;今天刷面经又刷到。。那就索性水一篇文吧&#xff01;更新&#xff1a;原题就是 leetcode 415 思路 & 代码 只要理好字符串s、字符串t、答案字符串的对应位关系就好啦&#x…

opcua 入门简介 java_大二的学生自学Java有出路吗?

这个是技术&#xff0c;学好了必须是有出路的&#xff0c;当然你喜不喜欢还得看后面的学习情况&#xff0c;三天热火气的情况大有人在&#xff0c;更有甚者就是&#xff0c;系统培训完&#xff0c;上了半年的班了&#xff0c;后转行到别的也有&#xff0c;所以兴趣是自己的最大…

【LeetCode笔记】232. 用栈实现队列(Java、栈、队列)

题目描述 经典题了&#xff0c;貌似现在面试也有点喜欢问&#xff0c;今天补补题&#xff01;要实现均摊时间复杂度O(1)噢 思路 & 代码 用两个栈来实现&#xff1a;输出栈 & 输入栈输出栈 out&#xff1a;负责 pop、peek输入栈 in&#xff1a;负责 push关键点&…

如何安全使用计算机,如何安全的使用计算机

如何安全的使用计算机导语&#xff1a;关于电脑的使用&#xff0c;如何正确的安全的使用好电脑&#xff0c;其实很多人都会有这个意识。以下是小编精心整理的有关电脑安全的知识&#xff0c;希望对大家有所帮助。一是要注意环境。环境温度在15℃&#xff5e;35℃为宜&#xff0…

调节e18-d80nk的测量距离_地坪研磨机磨盘平整度的调节方法及好处

地坪研磨机磨盘平整度的调节方法及好处名词解释调节磨盘平整度主要是指将四个磨盘调到静止或运转时磨盘趋向处于同一个平面。 调节方法 1、采用一把高度卡尺或任意一把尺条测量准确磨盘面到箱体底部边沿距离2、采用10MM内六角扳手、调节M12的不锈钢内六螺丝&#xff08;如图1&…

【LeetCode笔记】225. 用队列实现栈(Java、队列、栈)

题目描述 感觉栈实现队列更简单&#xff0c;不过这个也还好写法有点像 JVM GC 里的复制算法 思路 & 代码 两个队列实现栈&#xff1a;from、tofrom&#xff1a;实际上的栈&#xff0c;存储元素就是按照栈的顺序来&#xff0c;负责pop、topto&#xff1a;辅助队列&#…

微型计算机最怕的是什么,为什么以前学生上“微机课”都要穿鞋套?老师:怕电脑中病毒...

原标题&#xff1a;为什么以前学生上“微机课”都要穿鞋套&#xff1f;老师&#xff1a;怕电脑中病毒前不久&#xff0c;知乎上一则问答短短一周便收获了近400万浏览量。“为什么小时候去计算机教室要穿鞋套&#xff1f;”看着网友们的回复&#xff0c;小酷想起了小学时期&…

iphone屏蔽系统更新_手贱更新了 iphone系统,想退回到原来的版本,这个方法简单易用...

应该有很多人都很烦iphone的系统更新&#xff0c;开着wifi一夜睡醒&#xff0c;就欢迎你来到最新系统&#xff0c;新版本出来之后&#xff0c;各种媒体消息铺天盖地而来&#xff0c;类似于呼吁大家赶快更新享用新功能&#xff0c;殊不知系统更新有两种&#xff0c;都不适合马上…

【LeetCode笔记】438. 找到字符串中所有字母异位词(Java、字符串、滑动窗口)

题目描述 因为自己写的复杂度已经到了 O(n)&#xff0c;就没有再参考题解的优化了更新&#xff1a;滑动窗口方法 思路 & 代码 用一个 int[ ] count 来存储当前判断子串的各字母出现次数getCount()&#xff1a;对当前子串&#xff0c;求 count&#xff0c;时间复杂度 O(…

电脑入门完全自学手册_电气自动化自学宝典——看过人人都是工程师

原标题&#xff1a;电气自动化自学宝典——看过人人都是工程师怎样快速成为一名电气自动化工程师呢&#xff1f; 对于一些对电气技术一无所知或略有一点基础的人来说&#xff0c;要想成为一名电气自动化工程师或达到相同的技术程度&#xff0c;有什么速成的方法吗&#xff1f;如…

【LeetCode笔记】213. 打家劫舍II(Java、动态规划)

文章目录题目描述思路 & 代码更新版题目描述 在 I 的基础上&#xff0c;分成两部分&#xff0c;再取 Max 就行 思路 & 代码 由题意可知&#xff1a;一种路线中&#xff0c;不能同时出现第一家和最后一家。那么好办了&#xff0c;直接分成两部分分别取&#xff1a;不…

jflash view log_塑胶产品上的“LOG”是怎么来的?

“LOG”就是我们生产出来的产品的品牌.可以是单一的字组成&#xff1b;可以是图案组成&#xff1b;也可以由字与图案一起组成。一种是我们用模具生产出来的,通过模具上加工的字体生产出来的“LOG”,从而表现在产品上。而用模具直接生产出来的“LOG”,模具上有把做“LOG”字体做…

【LeetCode笔记】337. 打家劫舍III(Java、树型动态规划)

文章目录题目描述思路 & 代码更新版题目描述 这年头当个小偷&#xff0c;都得会 dp 和二叉树了和前面的 I & II 有点不同&#xff0c;这次直接换了数据结构&#xff0c;写树来了。&#xff08;之后不会是图吧&#xff09;很厉害&#xff0c;第一次接触到树型的dp&…

andriod studio 查看项目依赖_如何实施CRM项目管理

CRM 系统实施不当&#xff0c;不仅造成经济上的损失&#xff0c;而且会给企业的经营造成严重的影响&#xff0c;甚至导致崩溃。作为典型的高风险项目&#xff0c;CRM 系统实施必须进行严格的项目管理。而项目管理的内容非常丰富。下面简单描述CRM 项目管理中几个重要的方面。CR…

【LeetCode笔记】208. 实现Trie(前缀树)(Java、前缀树)

文章目录题目描述思路 & 代码更新版题目描述 属于那种&#xff0c;敲过一遍就不会忘了的那种题&#xff0c;就是学一个新的数据结构 二十六叉树&#xff01; 思路 & 代码 isEnd 非常重要噢&#xff0c;只有正式 insert 了的单词才能被 search 到。在 Trie 中实现内…

计算机的储存容量1kb等于多少byte,1M等于多少字节?

1M等于多少字节?以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;1M等于多少字节?不是1M等于多少字节&#xff0c;是1MB等于多少字节。字节(Byte /bait/ n. [C])是计算机信息技术用于计量存…

初中数学503个必考知识点_2020年中考数学必考知识点公布,考生高分、满分提分必备神器...

在孩子学习过程中&#xff0c;假设有一种“方法”&#xff0c;能让孩子成绩突飞猛进&#xff0c;你想不想掌握&#xff1f;在孩子学习过程中&#xff0c;假设有一套“系统”&#xff0c;能让孩子主动喜欢上学习&#xff0c;你想不想拥有&#xff1f;在孩子学习过程中&#xff0…