首页 > 试题广场 >

压缩算法

[编程题]压缩算法
  • 热度指数:5823 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 256M,其他语言512M
  • 算法知识视频讲解
小Q想要给他的朋友发送一个神秘字符串,但是他发现字符串的过于长了,于是小Q发明了一种压缩算法对字符串中重复的部分进行了压缩,对于字符串中连续的m个相同字符串S将会压缩为[m|S](m为一个整数且1<=m<=100),例如字符串ABCABCABC将会被压缩为[3|ABC],现在小Q的同学收到了小Q发送过来的字符串,你能帮助他进行解压缩么? 



示例1

输入

"HG[3|B[2|CA]]F"

输出

"HGBCACABCACABCACAF"

说明

HG[3|B[2|CA]]F−>HG[3|BCACA]F−>HGBCACABCACABCACAF

备注:
S的长度<=1000;
S仅包含大写字母、[、]、|;
解压后的字符串长度不超过100000;
压缩递归层数不超过10层;
头像 猪猪加油油
发表于 2021-03-20 15:33:55
class Solution { public: string compress(string str) { stack<char> st; for (int i = 0; i < str.size(); i++) { 展开全文
头像 小牛冲冲冲jiang
发表于 2021-09-23 00:19:46
记录区间的下标删除该区间 并替换成 该区间对应的字符串 import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @pa 展开全文
头像 大厂算法岗必拿下
发表于 2021-09-23 08:30:05
注意常用的一些脚标的细节。以及此题涉及的字符串使用,以及指针滑动逻辑 class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param str stri 展开全文
头像 连三月s
发表于 2022-03-16 11:22:39
DFS 和LeetCode 394题目,基本一样。 解法参考的ACVV的力扣究极班的写法。 加一个这个题目的通解吧。 这种类型的题目可以直接背过。 定义一个u的成员变量进行DFS,然后 碰到字母就append(),当碰到左括号,代表需要进入递归,然后把这个重复的数字算出来,递归的出口是碰到右括号。 展开全文