【华为OD机试c++】解压报文【2023 B卷 |200分】

本文介绍了华为在线测评中的一道C++编程题,涉及字符串压缩与解压缩。题目要求从输入的压缩报文恢复原始报文,压缩规则为数字n后面跟着小写字母串str表示str重复n次。解题关键在于利用栈来处理字符串中的嵌套括号,确保正确解压。示例展示了输入与输出的具体情况。
摘要由CSDN通过智能技术生成

题目描述

为了提升数据传输的效率,会对传输的报文进行压缩处理。

输入一个压缩后的报文,请返回它解压后的原始报文。

压缩规则:n[str],表示方括号内部的 str 正好重复 n 次。

注意 n 为正整数(0 < n <= 100),str只包含小写英文字母,不考虑异常情况。

输入描述

输入压缩后的报文:

1)不考虑无效的输入,报文没有额外的空格,方括号总是符合格式要求的;

2)原始报文不包含数字,所有的数字只表示重复的次数 n ,例如不会出现像 5b 或 3[8] 的输入;

输出描述

解压后的原始报文

注:

1)原始报文长度不会超过1000,不考虑异常的情况

示例1

输入

3[m2[c]]

1

输出

mccmccmcc

1

说明

m2[c] 解压缩后为 mcc,重复三次为 mccmccmcc

示例2

输入

10[k]2[mn3[j2[op]]]

1

输出

kkkkkkkkkkmnjopopjopopjopopmnjopopjopopjopop

1

解题思路

这道题是字符串处理的问题,同时字符串中嵌套括号,根据嵌套的括号进行报文解压缩,

很容易想到用栈去解决问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

2024剑指offer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值