news 2026/4/10 11:12:31

【剑斩OFFER】算法的暴力美学——力扣 394 题:字符串解码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【剑斩OFFER】算法的暴力美学——力扣 394 题:字符串解码

一、题目描述

二、算法原理

思路:使用双栈,一个栈原来存储字符串,另外一个存储整型数字;

1)一开始,把 string 栈先放个空字符串进去,方便后面操作;

2)如果碰到纯字母(非 [ 后面的字母),就让把这些字母提取出来拼接到 string 栈栈顶元素的后面:

3)如果遍历到数字,直接入 int 栈:

4)如果遍历到 ' [ ',就把 [ 后面的字母入 string 栈:

5)如果遍历到 ' ] ',就把双栈的栈顶元素拿出来,进行重复 K 次工作,重复结束之后把这个字符串拼接到栈顶元素的后面(这也是我为什么让 string 一开始放个空串进去的原因):

最终答案:此时 string 的栈顶元素就是最终答案:

三、代码实现

class Solution { public: string decodeString(string s) { vector<int> int_stack; vector<string> char_stack(1,""); for(int i = 0; i < s.size();) { if(s[i] == '[')// "[" 后面跟字母 { i++; string str = ""; while(!isdigit(s[i]) && s[i] != ']' && s[i] != '[') { str += s[i]; i++; } char_stack.push_back(str); } else if(isdigit(s[i]))//纯数字 { int tmp = 0; while(isdigit(s[i])) { tmp = tmp * 10 + (s[i] - '0'); i++; } int_stack.push_back(tmp); } else if(s[i] != ']') { //纯字母 string str; while(i < s.size() && !isdigit(s[i]) && s[i] != ']' && s[i] != '[') { str += s[i]; i++; } char_stack.back() += str; } else // "]" { //']' //取双栈元素 int k = int_stack.back(); string str = char_stack.back(); //出双栈元素 int_stack.pop_back(); char_stack.pop_back(); string ret = ""; for(int j = 0; j < k; j++) ret += str; char_stack.back() += ret; i++; } } return char_stack.back(); } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/9 21:54:31

Applite终极指南:Mac软件管理的革命性解决方案

Applite终极指南&#xff1a;Mac软件管理的革命性解决方案 【免费下载链接】Applite User-friendly GUI macOS application for Homebrew Casks 项目地址: https://gitcode.com/gh_mirrors/ap/Applite 还在为复杂的Homebrew命令而烦恼吗&#xff1f;Applite为您带来了Ma…

作者头像 李华
网站建设 2026/4/8 13:42:18

G-Helper:解锁华硕笔记本隐藏性能的终极利器

G-Helper&#xff1a;解锁华硕笔记本隐藏性能的终极利器 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models 项目地址: https:…

作者头像 李华
网站建设 2026/4/5 22:38:05

ResNet18性能优化:模型剪枝实战教程

ResNet18性能优化&#xff1a;模型剪枝实战教程 1. 引言&#xff1a;通用物体识别中的ResNet-18 在当前AI应用广泛落地的背景下&#xff0c;通用图像分类已成为智能系统的基础能力之一。从智能家居到自动驾驶&#xff0c;从内容审核到工业质检&#xff0c;精准、高效的图像识…

作者头像 李华
网站建设 2026/4/2 8:22:28

ResNet18部署教程:云端图像分类服务搭建

ResNet18部署教程&#xff1a;云端图像分类服务搭建 1. 引言&#xff1a;通用物体识别的工程价值 在当前AI应用快速落地的背景下&#xff0c;通用物体识别已成为智能监控、内容审核、辅助驾驶和AR交互等场景的核心能力之一。尽管大模型在多模态理解上表现突出&#xff0c;但在…

作者头像 李华
网站建设 2026/4/10 19:34:32

DownKyi终极攻略:解锁B站视频下载新境界

DownKyi终极攻略&#xff1a;解锁B站视频下载新境界 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等&#xff09;。 项…

作者头像 李华
网站建设 2026/4/8 17:00:14

DownKyi终极指南:5步掌握B站视频批量下载技巧

DownKyi终极指南&#xff1a;5步掌握B站视频批量下载技巧 【免费下载链接】downkyi 哔哩下载姬downkyi&#xff0c;哔哩哔哩网站视频下载工具&#xff0c;支持批量下载&#xff0c;支持8K、HDR、杜比视界&#xff0c;提供工具箱&#xff08;音视频提取、去水印等&#xff09;。…

作者头像 李华