zoukankan      html  css  js  c++  java
  • [Leetcode][Algo] 394. Decode String

    题目:

    The encoding rule is: k[encoded_string], where the encoded_string inside the square brackets is being repeated exactly k times. Note that k is guaranteed to be a positive integer.

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

     思路:

    讲真,这道题知道用栈,但是没啥思路。。。就是属于毛也写不出来的那种题。。。看了别人的答案才有点儿feel。。。可怕。

    1.  用两个栈,分别存储数字和中间字符串

    2. 局部字符串变量res,用来存储拼接最后的结果

    3. 遇到"["就是说要开始准备组合咯~~就要把之前的res,还有数字,都压栈保存起来。然后之前的数字啊,res都清空,为后面做准备。

    4. 遇到"]"就是说,哎呀这个需要decode的东东已经over了,可以开始啦。

      res里面保存的是需要重复的串,因为之前已经push_back了,相当于再重复的次数就是nums-1次。

          重复完了以后,把保存在chars 栈里面的字符串弹出来,接上。把用过的字符串和数字都弹出来。

    代码:

     1 class Solution {
     2 public:
     3     string decodeString(string s) {
     4         string res="";
     5         stack<string> chars;
     6         stack<int> nums;
     7         int num = 0;
     8         for(char c:s){
     9             if(isdigit(c)){  
    10                 num = num * 10 + c-'0'; //calc nums
    11             }
    12             else if(isalpha(c)){
    13                 res.push_back(c);  //form string
    14             }
    15             else if(c == '['){
    16                 nums.push(num);
    17                 chars.push(res);
    18                 num = 0;
    19                 res = "";
    20             }
    21             else if(c == ']'){
    22                 string temp = res;  //already push back once
    23                 for(int i = 0; i<nums.top()-1;i++){   
    24                     res += temp;
    25                 }
    26                 res = chars.top() + res;
    27                 chars.pop();
    28                 nums.pop();
    29             }
    30         }
    31         return res;
    32     }
    33 };
  • 相关阅读:
    僵尸进程与孤儿进程/守护进程/互斥锁
    基于udp协议支持并发的套接字/并发相关的概念/开启进程的两种方式/进程对象的方法
    python3和python2的区别
    安装python
    浅谈aiohttp和middlewares
    IO多路复用之select,poll,epoll个人理解
    python之进程,线程,协程简单理解
    Python类__call__()方法
    python中str与bytes
    测试理论基础三
  • 原文地址:https://www.cnblogs.com/hopping/p/8626189.html
Copyright © 2011-2022 走看看