题目

题目

s = "3[a]2[bc]", return "aaabcbc".
s = "3[a2[c]]", return "accaccacc".
s = "2[abc]3[cd]ef", return "abcabccdcdcdef".

大概意思是根据指定的格式将字符串进行展开

思路

  • 递归的思路

递归计算出括号最里面的字符串,依次再处理外面一层的字符串,每个单元内的字符串类似于一个结点,个数则为结点的个数。父结点则是将这些个数的字符串组合在一起,以此类推到跟结点,就是我们要求的结果。

  • 迭代的思路

用两个栈来分别保存下单元中的个数,另一个则保存单元中的字符串,注意的是,要将最新的处理完后的字符串加入到栈中。一直加入,直到最后返回栈顶字符串则为所求结果。

实现

//
// #include "../PreLoad.h" /*
s = "3[a]2[bc]", return "aaabcbc".
s = "3[a2[c]]", return "accaccacc".
s = "2[abc]3[cd]ef", return "abcabccdcdcdef".
*/ class Solution {
public:
// 错误做法
string decodeString(string s) {
if (s == "") {
return "";
} string result = "";
stack<pair<char, int>> codes;
codes.push({s[0], 0}); while (!codes.empty()) {
auto content = codes.top();
codes.pop(); // 表明开始是数字
if (content.first >= '0' && content.first <= '9') {
int start = content.second;
string nums = "";
nums.push_back(content.first);
while (s[start] != '\n' && s[start] != '[') {
content.first += s[start];
start++;
} // 计算单位的字符串
int num = atoi(nums.c_str());
string str = "";
for (int i = 0; i < num; i++) {
str += content.first;
}
result += str; // 找到下一个单位起始的位置
while (s[start] != '\n' && s[start] != ']') {
start++;
}
if (start != s.size()-1) {
start++;
codes.push({s[start], start});
}
}
} return result;
} /**
* 迭代DFS的做法
*
* @param s
* @return
*/
string decodeString2(string s) {
int cnt = 0; //每个单元里的数字个数
string content = ""; int len = s.size();
int i = 0;
stack<string> strs;
stack<int> cnts; while (i < len) {
// 为数字的情况
if (i < len && s[i] >= '0' && s[i] <= '9') {
cnt = cnt * 10 + (s[i] - '0');
}
// 为左括号的情况
else if (i < len && s[i] == '[') {
cnts.push(cnt);
strs.push(content); //因为存在内嵌的情况,所以保存下之前的单元内的字符串 cnt = 0;
content.clear(); //清空用来保存后面单元的字符串
}
// 为右括号的情况
else if (i < len && s[i] == ']') {
int cnt_temp = cnts.top();
cnts.pop(); while (cnt_temp--) {
strs.top() += content;
} // 将之前的字符串进行累加以后得到新的单元的内容
content = strs.top();
strs.pop();
}
// 中间的字符串
else {
content += s[i];
} i++;
} // 可能存在没有]的单元
return strs.empty() ? content : strs.top();
} /**
* 递归DFS
* 计算单元格内字符串的内容,再根据个数进行累加
* 注意字符串下标和边界条件
*
* @param s
* @return
*/
string decodeString3(string s) {
int len = s.size();
if (len == 0) {
return "";
}
int i = 0;
return decodeHelper(s, i);
} string decodeHelper(string s, int& i) {
string result = "";
int len = s.size();
while (i < len && s[i] != ']') {
// 非数字而是字符的情况下
if (s[i] < '0' || s[i] > '9') {
result += s[i++];
}
else {
// 计算数字
int cnt = 0;
while (s[i] >= '0' && s[i] <= '9' && i < len) {
cnt = cnt * 10 + (s[i++] - '0');
}
// 移动到字符串开始的位置
i++;
// 获得单元内的字符串,此时递归返回i的位置是]的位置
string str = decodeHelper(s, i);
//移动到下一个单元的位置
i++; while (cnt--) {
result += str;
}
}
} return result;
} void test() {
string str = "3[a2[c]]";
cout << "result : " << decodeString3(str) << endl;
}
};

总结:这些和在树中使用DFS的思想是类似的。

[LeetCode] Decode String 题解的更多相关文章

  1. [LeetCode] Decode String 解码字符串

    Given an encoded string, return it's decoded string. The encoding rule is: k[encoded_string], where ...

  2. LeetCode——Decode String

    Question Given an encoded string, return it's decoded string. The encoding rule is: k[encoded_string ...

  3. [LeetCode] 394. Decode String 解码字符串

    Given an encoded string, return it's decoded string. The encoding rule is: k[encoded_string], where ...

  4. LeetCode 394. 字符串解码(Decode String) 44

    394. 字符串解码 394. Decode String 题目描述 给定一个经过编码的字符串,返回它解码后的字符串. 编码规则为: k[encoded_string],表示其中方括号内部的 enco ...

  5. [LeetCode] Encode String with Shortest Length 最短长度编码字符串

    Given a non-empty string, encode the string such that its encoded length is the shortest. The encodi ...

  6. [LeetCode] Decode Ways 解题思路

    A message containing letters from A-Z is being encoded to numbers using the following mapping: 'A' - ...

  7. LeetCode——Reverse String

    LeetCode--Reverse String Question Write a function that takes a string as input and returns the stri ...

  8. Leetcode 8. String to Integer (atoi) atoi函数实现 (字符串)

    Leetcode 8. String to Integer (atoi) atoi函数实现 (字符串) 题目描述 实现atoi函数,将一个字符串转化为数字 测试样例 Input: "42&q ...

  9. Leetcode -- 394. Decode String

    Given an encoded string, return it's decoded string. The encoding rule is: k[encoded_string], where ...

随机推荐

  1. HDU 3782 xxx定律

    xxx定律 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  2. Oracle VS DB2 数据类型

    =========================Oracle VS DB2==================================== 本文转自:http://www.bitscn.co ...

  3. AWS EC2笔记

    朋友想搭一个境外网站,找我帮忙,希望服务器.域名都在境外.我没有在境外建站的经历,只能先尝试.于是上网搜索了一下境外服务器,大家比较常用的是Digital Ocean和AWS,我索性打开这两家的官网, ...

  4. ubuntu的常用命令

    1. locate------根据名字找文件,例如: locate php.ini 2.find----------以目录结构的形式搜索文件, 例如:find / -type d -iname jvm ...

  5. Ionic 2 中创建一个照片倾斜浏览组件

    内容简介 今天介绍一个新的UI元素,就是当我们改变设备的方向时,我们可以看到照片的不同部分,有一种身临其境的感觉,类似于360全景视图在移动设备上的应用. 倾斜照片浏览 Ionic 2 实例开发 新增 ...

  6. Python求解登楼梯问题(京东2016笔试题)

    问题:假设一段楼梯共15个台阶,小明一步最多能上3个台阶,那么小明上这段楼梯一共有多少种方法? 解析:从第15个台阶上往回看,有3种方法可以上来(从第14个台阶上一步迈1个台阶上来,从第13个台阶上一 ...

  7. 基于nginx+lua+redis高性能api应用实践

    基于nginx+lua+redis高性能api应用实践 前言 比较传统的服务端程序(PHP.FAST CGI等),大多都是通过每产生一个请求,都会有一个进程与之相对应,请求处理完毕后相关进程自动释放. ...

  8. awk,sed文本处理案例

    #!/bin/bash ############################################################################# #针对一个多级目录下 ...

  9. 【转】44款Java 网络爬虫开源软件

    原帖地址 http://www.oschina.net/project/lang/19?tag=64&sort=time 极简网络爬虫组件 WebFetch WebFetch 是无依赖极简网页 ...

  10. Material Design学习-----SnackBar

    SnackBar是一个和Toast类似的空间,用于弹出提示作用,但是相比于Toast而已,SnackBar会有一个不错的动画效果,同时当手指完成屏幕中其他操作的时候,SnackBar会立即消失.同时可 ...