■ 题目描述
- 为了提升数据传输的效率,会对传输的报文进行压缩处理。
- 输入一个压缩后的报文,请返回它解压后的原始报文。
- 压缩规则:n[str],表示方括号内部的 str 正好重复 n 次。
- 注意 n 为正整数(0 < n <= 100),str只包含小写英文字母,不考虑异常情况。
输入描述:
输入压缩后的报文:
1)不考虑无效的输入,报文没有额外的空格,方括号总是符合格式要求的;
2)原始报文不包含数字,所有的数字只表示重复的次数 n ,例如不会出现像 5b 或 3[8] 的输入;
输出描述:
解压后的原始报文
注:
1)原始报文长度不会超过1000,不考虑异常的情况
示例 1 输入输出示例仅供调试,后台判题数据一般不包含示例
输入
3[k]2[mn]
输出
kkkmnmn
说明
k 重复3次,mn 重复2次,最终得到 kkkmnmn
示例2 输入输出示例仅供调试,后台判题数据一般不包含示例
输入
3[m2[c]]
输出
mccmccmcc
说明
m2[c] 解压缩后为 mcc,重复三次为 mccmccmcc
以下代码为本人原创,可以供大家参考,若有不足之处,感谢指出!!!!
word = input()
stack, res, mulit = [], '', 0
for i in word:
if i == '[':
stack.append((res, mulit))
mulit, res = 0, ''
elif i == ']':
pre_res, pre_mulit = stack.pop()
res = pre_res + pre_mulit*res
elif '0' <= i <= '9':
mulit = mulit*10+int(i)
else:
res += i
print(res)
标签:pre,mulit,示例,res,报文,解压缩,面试,输入
From: https://blog.csdn.net/YW2019/article/details/137285687