睡觉觉觉得 2022-12-28 21:11 采纳率: 88.5%
浏览 55
已结题

关于#字符串#的问题,如何解决?

描述

小东发现了一种叫“懒人笔记”的记笔记的偷懒的办法

例如:

5个a 写作 5a

banana 写作 b2(an)a

这样记笔记就可以省事多啦!

输入
每组数据一个字符串,表示小东使用“懒人笔记”记录的内容,字符串长度不超过100.

字符串只包含数字和小写字母以及括号.

输出
请你输出这个使用“懒人笔记”的方法记录的原字符串的内容.

输入样例 1

a4ple
输出样例 1

ap四个p(包括前面那个)le
输入样例 2

2(china)
输出样例 2

chinachina
输入样例 3

noi2(c2p3(c))
输出样例 3

noicpp3个c(包括前面那个)pp3个c

输入输出里的文字不要!

  • 写回答

3条回答 默认 最新

  • 流比 2022-12-28 21:31
    关注
    
    #include <iostream>
    #include <string>
    #include <stack>
    
    using namespace std;
    
    string process(string str) {
        // 定义栈,用于存储字符串中的左括号
        stack<int> st;
        // 定义结果字符串
        string result;
        for (int i = 0; i < str.length(); i++) {
            // 如果遇到左括号,则将位置压入栈中
            if (str[i] == '(') {
                st.push(i);
            }
            // 如果遇到右括号
            else if (str[i] == ')') {
                // 取出栈顶的左括号位置
                int left = st.top();
                st.pop();
                // 取出左括号和右括号之间的字符串
                string s = str.substr(left + 1, i - left - 1);
                // 对字符串进行递归处理
                s = process(s);
                // 计算重复的次数
                int repeat = 0;
                for (int j = left - 1; j >= 0; j--) {
                    if (isdigit(str[j])) {
                        repeat = repeat * 10 + (str[j] - '0');
                    }
                    else {
                        break;
                    }
                }
                // 复制字符串
                for (int j = 0; j < repeat; j++) {
                    result += s;
                }
                // 跳过括号内的字符串
                i = left - 1;
            }
    // 如果当前字符是数字,则跳过
            else if (isdigit(str[i])) {
                continue;
            }
            // 其他字符直接添加到结果字符串中
            else {
                result += str[i];
            }
        }
        // 返回结果字符串
        return result;
    }
    
    int main() {
        string str;
        while (cin >> str) {
            cout << process(str) << endl;
        }
        return 0;
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月2日
  • 已采纳回答 2月2日
  • 专家修改了标签 1月18日
  • 修改了问题 12月28日
  • 展开全部

悬赏问题

  • ¥15 多址通信方式的抗噪声性能和系统容量对比
  • ¥15 winform的chart曲线生成时有凸起
  • ¥15 msix packaging tool打包问题
  • ¥15 finalshell节点的搭建代码和那个端口代码教程
  • ¥15 用hfss做微带贴片阵列天线的时候分析设置有问题
  • ¥15 Centos / PETSc / PETGEM
  • ¥15 centos7.9 IPv6端口telnet和端口监控问题
  • ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
  • ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
  • ¥20 海浪数据 南海地区海况数据,波浪数据