【LeetCode】两道栈相关的题目-394字符串解码,剑指Offer 09两个栈实现队列

本文主要是介绍【LeetCode】两道栈相关的题目-394字符串解码,剑指Offer 09两个栈实现队列,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 第394题:字符串解码
  • 剑指Offer 09题:两个栈实现队列

第394题:字符串解码

题目描述
给定一个经过编码的字符串,返回它解码后的字符串。
编码规则为: k[encoded_string],表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。
你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。
此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k ,例如不会出现像 3a 或 2[4] 的输入。

示例 1:

输入:s = “3[a]2[bc]”
输出:“aaabcbc”

示例 2:

输入:s = “3[a2[c]]”
输出:“accaccacc”

思路:(1)用一个栈来进行控制,每次遇到数字时将其转化为相应的字符串(思考可能遇到连续的两个或三个数字的情况),遇到 ’ [ ’ 或字母的时候直接入栈,遇到 ’ ] '进行弹栈操作;(2)弹栈时,将弹出的字母放入另一个栈中,因为弹栈的顺序不对,弹完后进行栈的翻转操作,继续将 ’ [ '弹出栈,然后弹出数字,并用数字控制字符串的数目。

几个常规操作:

  • 判断是否是数字 Character.isDigit(cur);
  • 判断是否是字母 Character.isLetter(cur);
  • 进栈操作 stack.addLast(digits); (栈选用的是LinkedList)
  • 弹栈 stack.removeLast();
  • 栈反转 Collections.reverse(sub);
  • 获取栈顶元素 stk.peekLast();
  • 字符串解析成数字 int rep = Integer.parseInt(stk.removeLast);

代码:

class Solution {//ptr为当前指针指向的字符串元素位置int ptr;public String decodeString(String s) {ptr = 0;//构造栈LinkedList<String> stack = new LinkedList<>();while(ptr < s.length()){char cur = s.charAt(ptr);//如果是数字,则构造数字的字符串if(Character.isDigit(cur)){String str = getDigit(s);stack.addLast(str);}else if(Character.isLetter(cur) || cur == '['){stack.addLast(String.valueOf(s.charAt(ptr++)));}//碰到了右括号else{++ptr;LinkedList<String> sub = new LinkedList<String>();while(!"[".equals(stack.peekLast())){sub.addLast(stack.removeLast());}//左括号弹栈stack.removeLast();int rep = Integer.parseInt(stack.removeLast());Collections.reverse(sub);String o = getString(sub);StringBuilder sb = new StringBuilder();while(rep>0){sb.append(o);rep--;}stack.addLast(sb.toString());}}return getString(stack);}/*** 将数字转化为字符串*/public String getDigit(String s){StringBuilder sb = new StringBuilder();while(Character.isDigit(s.charAt(ptr))){sb.append(s.charAt(ptr++));}return sb.toString();}/*** 将栈中的元素拼接为一个字符串*/public String getString(LinkedList<String> v){StringBuilder sb = new StringBuilder();for(String s : v){sb.append(s);}return sb.toString();}
}

剑指Offer 09题:两个栈实现队列

题目描述
用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )

示例 1:

输入:
[“CQueue”,“appendTail”,“deleteHead”,“deleteHead”]
[[],[3],[],[]]
输出:[null,null,3,-1]
示例 2:

示例2:

输入:
[“CQueue”,“deleteHead”,“appendTail”,“appendTail”,“deleteHead”,“deleteHead”]
[[],[],[5],[2],[],[]]
输出:[null,-1,null,null,5,2]

思路:两个栈S1和S2,S1用来进行入栈操作,S2为辅助栈,当需要出栈时,判断S2是否为空,若S2非空,则将S2中的一个元素弹栈,若S2为空,则继续判断S1是否为空,若S1非空,则将S1中的全部元素压入S2中,否则不能进行弹栈操作。将S1全部压入S2中,能够保证先进先出。

class CQueue {Deque<Integer> stack1;Deque<Integer> stack2;public CQueue() {stack1 = new LinkedList<>();stack2 = new LinkedList<>();}public void appendTail(int value) {stack1.push(value);}public int deleteHead() {if(stack2.isEmpty()){if(stack1.isEmpty()){return -1;}else{while(!stack1.isEmpty()){int temp = stack1.pop();stack2.push(temp);}return stack2.pop();}}else{return stack2.pop();}}
}

这篇关于【LeetCode】两道栈相关的题目-394字符串解码,剑指Offer 09两个栈实现队列的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/414224

相关文章

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

MyBatis Plus实现时间字段自动填充的完整方案

《MyBatisPlus实现时间字段自动填充的完整方案》在日常开发中,我们经常需要记录数据的创建时间和更新时间,传统的做法是在每次插入或更新操作时手动设置这些时间字段,这种方式不仅繁琐,还容易遗漏,... 目录前言解决目标技术栈实现步骤1. 实体类注解配置2. 创建元数据处理器3. 服务层代码优化填充机制详

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法