当前位置: 首页 > news >正文

HOT71-字符串解码

       leetcode原题链接: 字符串解码

题目描述

        给定一个经过编码的字符串,返回它解码后的字符串。

编码规则为: 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] 

解题方法:采用栈。遍历字符串,用字符串变量result保存最终的结果,遍历过程中用栈保存当前需要扩展的次数和待扩展字符串的首字母在result中的位置 。具体如下:

1)遇到数字,计算下需要扩展的次数;

2)遇到字母,则将字母追加到结果变量result中;

3)遇到[, 则将<扩展的次数count,扩展首字母在扩展遍历result中的位置> 保存在栈中,同时重置count的值为0;

4)遇到], 则开始扩展字符, 扩展的次数和扩展的字符都可以通过栈中的信息拿到。扩展完后,要将栈顶元素弹出。因为可能会有嵌套扩展的情况。如:3[a2[c]]

C++代码

#include <iostream>
#include <stack>
#include <string>
#include <utility> // std::pair
#include <cctype> //isdigit(), isalpha()
/*
* 解题方法:
* 扫描字符串:
*    1. 遇到数字,计算下需要扩展的次数
*    2. 遇到字母,则将字母追加到结果变量result中
*    3. 遇到[, 则将<扩展的次数count,扩展首字母在扩展遍历result中的位置>保存在栈中,同时重制count的值为0
*    4. 遇到], 则开始扩展字符, 扩展的次数和扩展的字符都可以通过栈中的信息拿到,扩展完后,要将栈顶元素弹出。因为可能
*            会有嵌套扩展的情况。
*/
class Solution {
public:string decodeString(std::string s) {int n = s.size();std::stack<std::pair<int, int>> st; //保存<本次扩展的次数count, 扩展字符串在result的开始位置>std::string result;int count = 0;for (int i = 0; i < n; i++) {if (isdigit(s[i])) { //数字count = 10 * count + (s[i] - '0');} else if (s[i] == '[') { //遇到左括号[ 则保存count和循环长度st.push({count, result.size()});count = 0;} else if (isalpha(s[i])) { //遇到字母,追加到result中result += s[i];} else if (s[i] == ']') { //遇到右括号] 则开始扩展int count = st.top().first;int start_pos = st.top().second;// abcd start_pos=0, len=4int len = result.size() - start_pos;std::string extend_str = result.substr(start_pos, len); //注意这里只能扩展count-1次,因为result上已经记录过一次了for (int k = 0; k < count - 1; k++) {result += extend_str;}st.pop(); //每扩展完都需要弹出栈顶元素,考虑这种情况: 3[a2[c]]  st: (3,0), (2, 1)}}return result;}
};

相关文章:

HOT71-字符串解码

leetcode原题链接: 字符串解码 题目描述 给定一个经过编码的字符串&#xff0c;返回它解码后的字符串。 编码规则为: k[encoded_string]&#xff0c;表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。你可以认为输入字符串总是有效的&#xff1b;输…...

redis-server进程无法关闭终极解决方案

先使用命令查看6379端口情况&#xff1a; sudo lsof -i :6379 发现redis进程在占用&#xff0c;redis-server进程无论什么手段都杀不死&#xff0c;使用kill -9 pid杀掉pid后又卷土重来&#xff0c;最后找到了下面这个命令 sudo /etc/init.d/redis-server stop ok&#xff0c…...

(5)将固件加载到没有ArduPilot固件的主板上

文章目录 前言 5.1 下载驱动程序和烧录工具 5.2 下载ArduPilot固件 5.3 使用测试版和开发版 5.3.1 测试版 5.3.2 最新开发版本 5.4 将固件上传到自动驾驶仪 5.5 替代方法 5.6 将固件加载到带有外部闪存的主板上 前言 ArduPilot 的最新版本&#xff08;Copter-3.6, Pl…...

wpf画刷学习1

在这2篇博文有提到wpf画刷&#xff0c; https://blog.csdn.net/bcbobo21cn/article/details/109699703 https://blog.csdn.net/bcbobo21cn/article/details/107133703 下面单独学习一下画刷&#xff1b; wpf有五种画刷&#xff0c;也可以自定义画刷&#xff0c;画刷的基类都…...

Opencv C++实现yolov5部署onnx模型完成目标检测

代码分析&#xff1a; 头文件 #include <fstream> //文件 #include <sstream> //流 #include <iostream> #include <opencv2/dnn.hpp> //深度学习模块-仅提供推理功能 #include <opencv2/imgproc.hpp> //图像处理模块 #include &l…...

django bootstrap html实现左右布局,带折叠按钮,左侧可折叠隐藏

一、实现的效果 在django项目中,需要使用bootstrap 实现一个左右分布的布局,左侧区域可以折叠隐藏起来,使得右侧的显示区域变大。(为了区分区域,左右加了配色,不好看的修改颜色即可) 点击折叠按钮,左侧区域隐藏,右侧区域铺满: 二、实现思路 1、使用col-md属性,让左…...

Mapping温度分布验证选择数据记录仪时需要考虑的13件事

01 什么是温度分布验证&#xff1f; 温度分布验证是通过在规定的研究时间内测量定义区域内的多个点来确定特定温度控制环境或过程&#xff08;如冷冻柜、冰箱、培养箱、稳定室、仓库或高压灭菌器&#xff09;的温度分布的过程。温度分布验证的目标是确定每个测量点之间的差异&…...

【题解】 判断一个链表是否为回文结构

判断一个链表是否为回文结构 题目链接&#xff1a;判断一个链表是否为回文结构 解题思路1&#xff1a;借助数组 遍历链表将值都放在数组中&#xff0c;再遍历数组元素&#xff0c;判断该数组是否为一个回文结构 代码如下&#xff1a; bool isPail(ListNode* head) {ListNod…...

Microsoft Message Queuing Denial-of-Service Vulnerability

近期官方公布了一个MSMQ的拒绝服务漏洞&#xff0c;可能因为网络安全设备的更新&#xff0c;影响业务&#xff0c;值得大家关注。 漏洞具体描述参见如下&#xff1a; Name: Microsoft Message Queuing Denial-of-Service Vulnerability Description: Microsoft Message Queuing…...

软件设计师(五)软件工程基础知识

一、软件工程概述 软件开发和维护过程中所遇到的各种问题称为“软件危机”。 软件工程是指应用计算机科学、数学及管理科学等原理&#xff0c;以工程化的原则和方法来解决软件问题的工程&#xff0c;其目的是提高软件生产率、提高软件质量、降低软件成本。 #mermaid-svg-h3j6K…...

Java中的JUnit单元测试方法的使用

Java中的JUnit单元测试方法 使用步骤如下&#xff1a; 选中当前工程 - 右键选择&#xff1a;build path - add libraries - JUnit 4 - 下一步创建Java类&#xff0c;进行单元测试。 此时的Java类要求&#xff1a;① 此类是public的 ②此类提供公共的无参的构造器此类中声明单…...

一文学透设计模式——抽象工厂模式

创建者模式 抽象工厂模式 概念 抽象工厂模式是围绕一个超级工厂创建其他工厂。该超级工厂又称为其他工厂的工厂。这种类型的设计模式属于创建型模式&#xff0c;它提供了一种创建对象的最佳方式。 这是很多地方对于抽象工厂模式的描述&#xff0c;说实话感觉不是特别好懂。…...

Vue3与Vue2区别和总结(1)

在2020年9月18日&#xff0c;Vue.js发布3.0版本&#xff0c;代号&#xff1a;One Piece&#xff08;海贼王&#xff09; 既然vue2已经存在了六七年之久为什么还要研发vue3呢&#xff1f; 那就不得不提vue3带来的提升了 1.Vue3带来了什么 1.性能的提升 打包大小减少41% 初次…...

【华秋推荐】物联网入门学习模块 ESP8266

随着全球信息技术的不断进步和普及&#xff0c;物联网成为当今备受关注的技术热点之一。通过物理和数字设备之间的连接来实现自动化和互联互通的网络。无线传感器、云计算和大数据分析等技术&#xff0c;物联网使设备能够相互交流和共享信息&#xff0c;实现智能化的自动化操作…...

本科专科毕业论文如何选题-附1000多论文题目-论文选题--【毕业论文】

文章目录 本系列校训毕设的技术铺垫论文选题选题目的和意义&#xff1a;选题举例参考文献 配套资源 本系列校训 互相伤害互相卷&#xff0c;玩命学习要你管&#xff0c;天生我才必有用&#xff0c;我命由我不由天&#xff01; 毕业论文不怕难&#xff0c;毕业设计来铺垫&#…...

pip安装jupyter notebook

之前电脑安装了anaconda&#xff0c;里面安装了jupyter notebook&#xff0c;用来做PPT之类的展示总让我觉得有点“炫酷”。 现在换了新电脑。没有anaconda&#xff0c;纯粹只是装了python3.11&#xff0c;然后突然也想手工安装下jupyter notebook&#xff0c;于是只能通过pip方…...

STM32刷Micropython固件参考指南

STM32刷Micropython固件指南 其实刷固件和普通的程序下载烧录无多大的差异&#xff0c;主要是其他因数的影响导致刷固件或刷完固件无法运行的情况和相关问题。 &#x1f4d1;刷固件教程 固件下载。目前所支持的stm32型号有这些&#xff1a; stm32f0, stm32f4, stm32f7, stm32g…...

学生信息管理系统自动化测试

项目地址&#xff1a; http://82.156.151.156:8080/login.html 一、系统测试用例 二、测试实现过程 先是根据自己的项目设计了一个 UI 自动化测试用例, 然后根据这个测试用例使用了 selenium4自动化测试工具和 JUnit5单元测试框架结合实现的 web 自动化测试.。 测试模块划分…...

Java面向对象之toString()方法

toString()方法 toString()方法在Object类中定义&#xff0c;其返回值是String类型&#xff0c;返回类名和它的引用地址。在进行String与其它类型数据的连接操作时&#xff0c;自动调用toString()方法。 Date nownew Date(); System.out.println(“now”now); 相当于 System.…...

MySQL(一)

mysql简介 1、什么是数据库 &#xff1f; 数据库&#xff08;Database&#xff09;是按照数据结构来组织、存储和管理数据的仓库&#xff0c;它产生于距今六十多年前&#xff0c;随着信息技术和市场的发展&#xff0c;特别是二十世纪九十年代以后&#xff0c;数据管理不再仅仅…...

三分钟解决内存焦虑:Mem Reduct实时内存管理工具深度解析

三分钟解决内存焦虑&#xff1a;Mem Reduct实时内存管理工具深度解析 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct …...

这 12 个神级免费工具,我用了才知道白白多花了好几年冤枉钱!

&#x1f6e0;️这 12 个神级免费工具&#xff0c;我用了才知道白白多花了好几年冤枉钱&#xff01;AI写作 / 视频剪辑 / 图片处理 / 效率提升全部免费可用&#xff0c;链接直接点&#xff0c;手机电脑都支持阅读约 6 分钟 强烈建议收藏转发很多人不知道&#xff1a;那些动辄几…...

一文搞懂 Spring Cloud:从入门到实战的微服务全景指南(建议收藏)炯

一、中间件是啥&#xff1f;咱用“餐厅”打个比方 想象一下&#xff0c;你的FastAPI应用是个高级餐厅。 ?? 顾客&#xff08;客户端请求&#xff09;来到门口。- 迎宾&#xff08;CORS中间件&#xff09;&#xff1a;先看你是不是从允许的街区&#xff08;域名&#xff09;来…...

告别手动排版!用NoteExpress一键搞定Elsevier期刊投稿的参考文献格式

科研效率革命&#xff1a;NoteExpress全自动参考文献排版实战指南 当你熬过无数个深夜终于完成论文初稿&#xff0c;却在参考文献排版环节卡壳时&#xff0c;那种挫败感我太熟悉了。去年投稿Elsevier期刊的经历让我深刻体会到&#xff0c;手动调整参考文献格式不仅耗时费力&…...

【CVE-2026-25253】--漏洞复现、漏洞原理以及修复建议

前言‌ OpenClaw‌ 是一款 ‌开源、本地优先的 AI 智能体框架‌,核心目标是让 AI 从“只会聊天”升级为“能动手执行真实任务”,被社区亲切地称为“‌龙虾 AI‌”或“‌小龙虾‌”‌ 一、漏洞概述 1、详情 CVE-2026-25253是OpenClaw控制界面(Control UI)中存在的跨站We…...

uni-app中H5页面通过web-view跳转小程序的完整解决方案

1. 为什么H5页面跳转小程序会报错&#xff1f; 最近在做一个uni-app项目时&#xff0c;遇到了一个典型问题&#xff1a;在H5页面中通过web-view跳转小程序时&#xff0c;控制台报错"wx.miniProgram is undefined"或者"navigateTo is undefined"。这个问题困…...

Janus-Pro-7B GPU算力优化:梯度检查点+FlashAttention-2显存节省35%

Janus-Pro-7B GPU算力优化&#xff1a;梯度检查点FlashAttention-2显存节省35% 1. 引言&#xff1a;大模型显存优化的迫切需求 Janus-Pro-7B作为DeepSeek推出的统一多模态模型&#xff0c;在图像理解与生成任务上表现出色&#xff0c;但其7B参数的规模对GPU显存提出了极高要求…...

深度学习基于YOLOV11罂粟识别检测系统 YOLOV11框架如何训练无人机罂粟识别检测数据集 航拍罂粟数据集的训练及应用

深度学习基于YOLOV11罂粟识别检测系统 YOLOV11框架如何训练无人机罂粟识别检测数据集 航拍罂粟数据集的训练及应用 1以下是构建该系统的详细步骤和完整代码。第一步&#xff1a;环境准备 首先&#xff0c;你需要安装最新的 Ultralytics 库&#xff08;支持 YOLOv11&#xff09…...

Rust 内存分配与所有权管理

Rust 内存分配与所有权管理&#xff1a;安全与性能的完美平衡 在编程语言的世界中&#xff0c;内存管理一直是开发者面临的核心挑战之一。传统语言如 C/C 依赖手动管理内存&#xff0c;容易引发内存泄漏或悬垂指针&#xff1b;而 Java 等语言采用垃圾回收机制&#xff08;GC&a…...

南北阁Nanbeige 4.1-3B入门必看:纯本地运行、无网依赖、4GB显存友好部署指南

南北阁Nanbeige 4.1-3B入门必看&#xff1a;纯本地运行、无网依赖、4GB显存友好部署指南 想体验一个能流畅对话、还能“看见”它思考过程的AI助手吗&#xff1f;今天要介绍的南北阁Nanbeige 4.1-3B&#xff0c;就是一个让你在普通电脑上就能跑起来的国产小模型。它只有30亿参数…...