LeetCode 热题 100_字符串解码(71_394_中等_C++)(栈)

LeetCode 热题 100_字符串解码(71_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”

示例 3:
输入:s = “2[abc]3[cd]ef”
输出:“abcabccdcdcdef”

示例 4:
输入:s = “abc3[cd]xyz”
输出:“abccdcdcdxyz”

提示:
1 <= s.length <= 30
s 由小写英文字母、数字和方括号 ‘[]’ 组成
s 保证是一个 有效 的输入。
s 中所有整数的取值范围为 [1, 300]

题解:

解题思路:

思路一(栈):

1、通过中括号内嵌中括号的情况,且内嵌的中括号首先计算,可以想到栈的方法解决此问题。
字符串中有四种字符:
① 数字:将数字转换为整数(数字的位数可为多位),称为字符串的重复次数
② 字母:将连续的字母提取出来,连接成字符串
③ 左括号:重复次数和字符串 分别入 数字栈和字符串栈
④ 右括号:弹出状态(出栈),重复n次对应字符串,并连接字符串

例子:s = “3[a2[c]]”
初始状态:k=0 (数字), current=“” (部分字符串), counts栈为空,strings栈为空
① 3 为数字字符,计算连续的数字字符并转换为整数,k=3;
② [ 为左括号,将k=3 和 current=““分别压入 counts栈={3}和strings={””}栈,重置k=0,current=“”
③ a 为字母,计算连接的字母,current=“a”;
④ 2 k=2;
⑤ [ 将k=2 和 current=“a” 分别压入 counts栈={3,2}和strings栈={“”,“a”},重置k=0,current=“”
⑥ c current=“c”;
⑦ ] 遇到右括号,将counts栈={3,2}中的2出栈,此时current=“c"重复2次 -> current=“cc”,strings栈={”“,“a”}中的"a"出栈,与current连接"acc”
⑧ ] 遇到右括号,counts栈={3}中的3出栈,此时current=“acc"重复3次->current = “accaccacc”,strings栈={”“}中的”“出栈,与current连接"accaccacc”

2、复杂度分析:
① 时间复杂度: O(S),S代表解码后得出的字符串长度,我们在遍历原字符串的同时会也会将解码后的字符串压入栈中,且进行字符串的连接。
② 空间复杂度:O(S),S代表解码后得出的字符串长度,栈的总大小最终与 S 相同。

代码实现

代码实现(栈):
class Solution {
public:
    string decodeString(string s) {
        stack<int> counts;  // 用来存储数字 (重复次数),栈用来存储每个 "[" 对应的重复次数
        stack<string> strings;  // 用来存储之前的部分字符串,栈用来存储每个 "[" 之前的字符串
        string current = "";  // 用来存储当前正在构建的字符串(用于存放当前解析出来的子字符串)
        int k = 0;  // 用来存储当前的重复次数

        // 遍历字符串中的每个字符
        for (char c : s) {
            if (isdigit(c)) {
                // 如果是数字,构建重复次数 k,直到遇到非数字字符
                k = k * 10 + (c - '0');  // 处理可能多位的数字
            } else if (c == '[') {
                // 如果遇到 '[',说明要开始一个新的子字符串块
                counts.push(k);  // 将当前的重复次数推入栈中
                strings.push(current);  // 将当前构建的字符串推入栈中

                current = "";  // 清空当前字符串,准备构建新的子字符串
                k = 0;  // 重置重复次数为 0,开始处理新的重复数字
            } else if (c == ']') {
                // 如果遇到 ']',说明当前子字符串块的解析结束
                string temp = current;   // 将当前的字符串保存到 temp 中
                current = strings.top(); // 从栈中获取之前的字符串部分
                strings.pop();  // 弹出栈中的字符串部分
                int repeatCount = counts.top();  // 从栈中获取重复次数
                counts.pop();  // 弹出栈中的重复次数

                // 将当前子字符串重复 repeatCount 次,并拼接到之前的部分
                for (int i = 0; i < repeatCount; i++) {
                    current += temp;  // 重复并拼接
                }
            } else {
                // 普通字符,直接加入当前正在构建的字符串
                current += c;
            }
        }
        return current;  // 返回解码后的最终字符串
    }
};
以思路一为例进行调试
#include<iostream>
#include<stack>
using namespace std;

class Solution {
public:
    string decodeString(string s) {
        stack<int> counts;  // 用来存储数字 (重复次数),栈用来存储每个 "[" 对应的重复次数
        stack<string> strings;  // 用来存储之前的部分字符串,栈用来存储每个 "[" 之前的字符串
        string current = "";  // 用来存储当前正在构建的字符串(用于存放当前解析出来的子字符串)
        int k = 0;  // 用来存储当前的重复次数

        // 遍历字符串中的每个字符
        for (char c : s) {
            if (isdigit(c)) {
                // 如果是数字,构建重复次数 k,直到遇到非数字字符
                k = k * 10 + (c - '0');  // 处理可能多位的数字
            } else if (c == '[') {
                // 如果遇到 '[',说明要开始一个新的子字符串块
                counts.push(k);  // 将当前的重复次数推入栈中
                strings.push(current);  // 将当前构建的字符串推入栈中

                current = "";  // 清空当前字符串,准备构建新的子字符串
                k = 0;  // 重置重复次数为 0,开始处理新的重复数字
            } else if (c == ']') {
                // 如果遇到 ']',说明当前子字符串块的解析结束
                string temp = current;   // 将当前的字符串保存到 temp 中
                current = strings.top(); // 从栈中获取之前的字符串部分
                strings.pop();  // 弹出栈中的字符串部分
                int repeatCount = counts.top();  // 从栈中获取重复次数
                counts.pop();  // 弹出栈中的重复次数

                // 将当前子字符串重复 repeatCount 次,并拼接到之前的部分
                for (int i = 0; i < repeatCount; i++) {
                    current += temp;  // 重复并拼接
                }
            } else {
                // 普通字符,直接加入当前正在构建的字符串
                current += c;
            }
        }
        return current;  // 返回解码后的最终字符串
    }
};

int main(int argc, char const *argv[])
{
    string str="3[a2[c]]";

    Solution s;
    string ans=s.decodeString(str);
    cout<<ans;
    return 0;
}

LeetCode 热题 100_字符串解码(71_394)原题链接
欢迎大家和我沟通交流(✿◠‿◠)

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

下载Hugging Face模型的几种方式

1.网页下载 直接访问Hugging Face模型页面&#xff0c;点击“File and versions”选项卡&#xff0c;选择所需的文件进行下载。 2.使用huggingface-cli 首先&#xff0c;安装huggingface_hub: pip install huggingface_hub 然后&#xff0c;使用以下命令下载模型&#xff1…

【Dubbo+Zookeeper】——SpringBoot+Dubbo+Zookeeper知识整合

&#x1f3bc;个人主页&#xff1a;【Y小夜】 &#x1f60e;作者简介&#xff1a;一位双非学校的大二学生&#xff0c;编程爱好者&#xff0c; 专注于基础和实战分享&#xff0c;欢迎私信咨询&#xff01; &#x1f386;入门专栏&#xff1a;&#x1f387;【MySQL&#xff0…

DeepSeek R1 学习笔记

DeepSeek为了方便大众的使用&#xff0c;同时提供了6个蒸馏版本 DeekSeek使用方式 1.大众方式&#xff1a; 网页版&#xff1a;DeepSeek App版&#xff1a;手机各大应用商店下载安装DeepSeek-AI智能对话助手 2.专业用户 开发者&#xff1a;调用API DeepSeek服务器 网址&a…

《从零构建企业级容器镜像生态:Harbor与Registry双星架构实战手记》

目录 一、企业级镜像中枢&#xff1a;Harbor架构深度解析 1.Harbor介绍 环境准备 2. Harbor战略部署 下载安装Harbor 关键配置文件 报错一 添加本地解析 登录测试Harbor 报错二 登录成功 测试 成功显示 二、轻量化镜像驿站&#xff1a;Registry闪电战部署 简单介…

FPGA之USB通信实战:基于FX2芯片的Slave FIFO回环测试详解

FPGA之Usb数据传输 Usb 通信 你也许会有疑问&#xff0c;明明有这么多通信方式和数据传输&#xff08;SPI、I2C、UART、以太网&#xff09;为什么偏偏使用USB呢? 原因有很多&#xff0c;如下&#xff1a; 1. 高速数据传输能力 高带宽&#xff1a;USB接口提供了较高的数据传…

mysql中in和exists的区别?

大家好&#xff0c;我是锋哥。今天分享关于【mysql中in和exists的区别?】面试题。希望对大家有帮助&#xff1b; mysql中in和exists的区别? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在 MySQL 中&#xff0c;IN 和 EXISTS 都用于进行子查询&#xff0c;但它…

Unity摄像机跟随物体

功能描述 实现摄像机跟随物体&#xff0c;并使物体始终保持在画面中心位置。 实现步骤 创建脚本&#xff1a;在Unity中创建一个新的C#脚本&#xff0c;命名为CameraFollow。 代码如下&#xff1a; using UnityEngine;public class CameraFollow : MonoBehaviour {public Tran…

springcloud sentinel教程

‌QPS&#xff08;Queries Per Second&#xff09;即每秒查询率 TPS&#xff0c;每秒处理的事务数目 PV&#xff08;page view&#xff09;即页面浏览量 UV 访问数&#xff08;Unique Visitor&#xff09;指独立访客访问数 一、初识Sentinel 什么是雪崩问题? 微服务之间相…

【Tools】Windows下Git 2.48安装教程详解

00. 目录 文章目录 00. 目录01. Git简介02. Git参考资料03. Git安装04. Git测试05. 附录 01. Git简介 Git(读音为/gɪt/。)是一个开源的分布式版本控制系统&#xff0c;可以有效、高速的处理从很小到非常大的项目版本管理。 [1] Git 是 Linus Torvalds 为了帮助管理 Linux 内核…

【Linux系统编程】初识系统编程

目录 一、什么是系统编程1. 系统编程的定义2. 系统编程的特点3. 系统编程的应用领域4. 系统编程的核心概念5. 系统编程的工具和技术 二、操作系统四大基本功能1. 进程管理&#xff08;Process Management&#xff09;2. 内存管理&#xff08;Memory Management&#xff09;3. 文…

神经网络|(十四)|霍普菲尔德神经网络-Hebbian训练

【1】引言 前序学习进程中&#xff0c;除了对基本的神经网络知识进行了学习&#xff0c;还掌握了SOM神经网络原理&#xff0c;文章链接包括且不限于&#xff1a; 神经网络|(十一)|神经元和神经网络-CSDN博客 神经网络|(十二)|常见激活函数-CSDN博客 神经网络|(十三)|SOM神经…

Hive八股

Hive八股 说一下GC模型遇到过gc调优吗yarn有哪些了解讲讲hqI转化为MR源码hbase读写流程hive数据倾斜page cache和buffer的区别和相同近来你关注了大数据生态哪些领域的发展&#xff0c;比如新的feature&#xff0c;新的领域等 Hive1Hive1hive简介2hive架构3hive与Hadoop的关系4…

Docker 部署 Graylog 日志管理系统

Docker 部署 Graylog 日志管理系统 前言一、准备工作二、Docker Compose 配置三、启动 Graylog 服务四、访问 Graylog Web 界面总结 前言 Graylog 是一个开源的日志管理平台&#xff0c;专为实时日志收集、分析和可视化设计。它支持强大的搜索功能&#xff0c;并且与 Elastics…

im即时聊天客服系统SaaS还是私有化部署:成本、安全与定制化的权衡策略

随着即时通讯技术的不断发展&#xff0c;IM即时聊天客服系统已经成为企业与客户沟通、解决问题、提升用户体验的重要工具。在选择IM即时聊天客服系统时&#xff0c;企业面临一个重要决策&#xff1a;选择SaaS&#xff08;软件即服务&#xff09;解决方案&#xff0c;还是进行私…

MySQL(单表)知识点

文章目录 1.数据库的概念2.下载并配置MySQL2.1初始化MySQL的数据2.2注册MYSQL服务2.3启动MYSQL服务2.4修改账户默认密码2.5登录MYSQL2.6卸载MYSQL 3.MYSQL数据模型3.1连接数据库 4.SQL简介4.1SQL的通用语法4.2SQL语句的分类4.3DDL语句4.3.1数据库4.3.2表(创建,查询,修改,删除)4…

同为科技智能PDU在数据中心场景的应用与解决方案

数据中心当前处于一个快速发展和技术变革的特殊时期&#xff0c;全新的人工智能应用正在重塑整个世界&#xff0c;为社会带来便捷的同时&#xff0c;也为数据中心的发展带来了新的机遇和挑战。智能算例的爆发式增长&#xff0c;对数据中心提出了大算力、高性能的新需求&#xf…

基于Asp.net的零食购物商城网站

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

Redis|Springboot集成Redis

文章目录 总体概述本地Java连接Redis常见问题集成Jedis集成lettuce集成RedisTemplate——推荐使用连接单机连接集群 总体概述 jedis-lettuce-RedisTemplate三者的联系 jedis第一代lettuce承上启下redistemplate着重使用 本地Java连接Redis常见问题 bind配置请注释掉保护模式…

【编译器】VSCODE编译C语言

【编译器】VSCODE编译C语言 文章目录 [TOC](文章目录) 前言一、下载配置二、代码1.main.c2.lanuch3.task 三、编译运行——方法一&#xff1a;编译器运行1.编译&#xff1a;终端-运行生成任务&#xff08;ctrlshiftB&#xff09;2.运行&#xff1a;运行-启动调试&#xff08;F5…

信息安全访问控制、抗攻击技术、安全体系和评估(高软42)

系列文章目录 信息安全访问控制、抗攻击技术、安全体系和评估 文章目录 系列文章目录前言一、信息安全技术1.访问控制2.抗攻击技术 二、欺骗技术1.ARP欺骗2.DNS欺骗3.IP欺骗 三、抗攻击技术1.端口扫描2.强化TCP/IP堆栈 四、保证体系和评估1.保证体系2.安全风险管理 五、真题在…