• LeetCode 394. 字符串解码


    题目链接

    力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

    题目解析

            使用栈来很好的解决每一个中括号(包含前边的数字)的重复插入问题。

            我们首先创建一个栈,栈中的数据是一个个的键值对{count,ans.size()};分别是当前字符串重复的次数,和当前字符串在ans的其实下标。ans代表的是遍历到当前字符的正确答案。

            当遍历到数字的时候我们将其记录下来(使用count记录)。

            当遍历到 '[' 将此时的count与此时的ans的长度(也就是此时这一小段重复元素的起始位置)给记录到栈中。

            当遍历到 ']' 则开始进行对此时的一对中括号中的数进行操作,然后出栈此时的栈顶元素,因为此时栈顶已经被使用过了。

    代码

    1. class Solution
    2. {
    3. public:
    4. string decodeString(string s)
    5. {
    6. // 该字符串用来记录我们的最终答案
    7. string ans;
    8. // 保存[前的数字
    9. int count=0;
    10. // 用来存放{count,ans.size()};
    11. // 分别是当前字符串重复的次数,和当前字符串在ans的其实下标
    12. stackint,int>> st;
    13. for(auto&ch:s)
    14. {
    15. // 若是数字,则进行记录
    16. if(isdigit(ch))
    17. {
    18. count=count*10+ch-'0';
    19. }
    20. // 若是'[' 则将此位置和重复数字组成键值对入栈
    21. else if(ch=='[')
    22. {
    23. st.push({count,ans.size()});
    24. count=0;
    25. }
    26. // 若是字母,则直接插入ans
    27. else if(isalpha(ch))
    28. {
    29. ans+=ch;
    30. }
    31. // 若是']',则开始进行对此时的一对中括号中的数进行操作
    32. // 然后出栈记录当前中括号中数据的键值对
    33. else if(ch==']')
    34. {
    35. // n就是该短字符串出现的次数
    36. int n=st.top().first;
    37. // 根据起始位置和长度进行截取
    38. string str=ans.substr(st.top().second,ans.size()-st.top().second);
    39. // 遍历循环插入
    40. for(int i=0;i-1;i++)
    41. {
    42. ans+=str;
    43. }
    44. // 出栈
    45. st.pop();
    46. }
    47. }
    48. return ans;
    49. }
    50. };

  • 相关阅读:
    【TensorFlow2 之012】TF2.0 中的 TF 迁移学习
    2023年英语二大作文押题猜想(达立易考)
    Linux(Nginx)
    17.Http__Linux
    【无标题】
    [Linux系统编程]文件重定向dup和dup2
    wifi7有关的210个提案
    golang开发类库推荐
    程序员如果都懂SpringWebFlux框架的话,也不用天天CRUD了
    GO 常用设计模式
  • 原文地址:https://blog.csdn.net/m0_57249790/article/details/132994308