394. 字符串解码
一、题目
给定一个经过编码的字符串,返回它解码后的字符串。
编码规则为: k[encoded_string]
,表示其中方括号内部的 encoded_string
正好重复 k
次。注意 k
保证为正整数。
你可以认为输入字符串总是有效的;输入字符串中没有额外的空格,且输入的方括号总是符合格式要求的。
此外,你可以认为原始数据不包含数字,所有的数字只表示重复的次数 k
,例如不会出现像 3a
或 2[4]
的输入。
二、思路
要我们类似于制作一个能使用分配律的计算器。想象:如3[a2[c]b] 使用一次分配律-> 3[accb] 再使用一次分配律->accbaccbaccb
三、代码
class Solution { public: string decodeString(string s) { string res = ""; stack <int> nums; stack <string> strs; int num = 0; int len = s.size(); for(int i = 0; i < len; ++ i) { if(s[i] >= '0' && s[i] <= '9') { num = num * 10 + s[i] - '0'; } else if((s[i] >= 'a' && s[i] <= 'z') ||(s[i] >= 'A' && s[i] <= 'Z')) { res = res + s[i]; } else if(s[i] == '[') //将‘[’前的数字压入nums栈内, 字母字符串压入strs栈内 { nums.push(num); num = 0; strs.push(res); res = ""; } else //遇到‘]’时,操作与之相配的‘[’之间的字符,使用分配律 { int times = nums.top(); nums.pop(); for(int j = 0; j < times; ++ j) strs.top() += res; res = strs.top(); //之后若还是字母,就会直接加到res之后,因为它们是同一级的运算 //若是左括号,res会被压入strs栈,作为上一层的运算 strs.pop(); } } return res; } };
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了