P1928 外星密码(dfs)

题目描述

有了防护伞,并不能完全避免 2012 的灾难。地球防卫小队决定去求助外星种族的帮助。经过很长时间的努力,小队终于收到了外星生命的回信。但是外星人发过来的却是一串密码。只有解开密码,才能知道外星人给的准确回复。解开密码的第一道工序就是解压缩密码,外星人对于连续的若干个相同的子串 X 会压缩为 [DX] 的形式(D 是一个整数且 1≤D≤99),比如说字符串 CBCBCBCB 就压缩为 [4CB] 或者[2[2CB]],类似于后面这种压缩之后再压缩的称为二重压缩。如果是 [2[2[2CB]]] 则是三重的。现在我们给你外星人发送的密码,请你对其进行解压缩。

输入格式

输入一行,一个字符串,表示外星人发送的密码。

输出格式

输出一行,一个字符串,表示解压缩后的结果。

输入输出样例

输入 #1复制

复制代码
AC[3FUN]

输出 #1复制

复制代码
ACFUNFUNFUN

说明/提示

【数据范围】

对于 50% 的数据:解压后的字符串长度在 1000 以内,最多只有三重压缩。

对于 100% 的数据:解压后的字符串长度在 20000 以内,最多只有十重压缩。保证只包含数字、大写字母、[]

java 复制代码
package q1;

import java.util.*;

public class Main {
    static int i = 0;  // 处理索引
    static int n; 	   // 字符串长度
    static String input;
    
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        input = scanner.nextLine();
        n = input.length();
        String res = f();
        System.out.println(res);
    }
    
    public static String f() {
        StringBuilder s = new StringBuilder();
        
        while (i < n) {
            char c = input.charAt(i);
            i++;
            
            if (c == '[') {
                int D = 0;   // 读取压缩次数 D
                while (i < n && Character.isDigit(input.charAt(i))) {
                    D = D * 10 + (input.charAt(i) - '0');
                    i++;
                }
                
                String X = f();
                for (int i = 0; i < D; i++) {
                    s.append(X);
                }
            } else if (c == ']') {  // 压缩区结束,返回当前结果
                return s.toString();
            } else {   // 普通字符,直接添加到结果
                s.append(c);
            }
        }
        
        return s.toString();
    }
}
相关推荐
打工的小王7 小时前
java并发编程(七)ReentrantReadWriteLock
java·开发语言
lang201509287 小时前
Java并发革命:JSR-133深度解析
java·开发语言
木非哲7 小时前
机器学习--从“三个臭皮匠”到 XGBoost:揭秘 Boosting 算法的“填坑”艺术
算法·机器学习·boosting
abluckyboy7 小时前
基于 Java Socket 实现多人聊天室系统(附完整源码)
java·开发语言
Re.不晚7 小时前
JAVA进阶之路——数据结构之线性表(顺序表、链表)
java·数据结构·链表
毅炼7 小时前
Java 基础常见问题总结(3)
java·开发语言
小辉同志7 小时前
437. 路径总和 III
算法·深度优先·广度优先
笨笨阿库娅7 小时前
从零开始的算法基础学习
学习·算法
亓才孓7 小时前
[JDBC]事务
java·开发语言·数据库
CHU7290357 小时前
直播商城APP前端功能全景解析:打造沉浸式互动购物新体验
java·前端·小程序