十一届蓝桥杯 字符串编码

时间限制: 1.0s 内存限制: 512.0MB 本题总分:25 分

【问题描述】

小明发明了一种给由全大写字母组成的字符串编码的方法。对于每一个大

写字母,小明将它转换成它在 26 个英文字母中序号,即 A → 1, B → 2, … Z →

26。

这样一个字符串就能被转化成一个数字序列:

比如 ABCXYZ → 123242526。

现在给定一个转换后的数字序列,小明想还原出原本的字符串。当然这样

的还原有可能存在多个符合条件的字符串。小明希望找出其中字典序最大的字

符串。

【输入格式】

一个数字序列。

【输出格式】

一个只包含大写字母的字符串,代表答案

【样例输入】

123242526

【样例输出】

LCXYZ

【评测用例规模与约定】

对于 20% 的评测用例,输入的长度不超过 20。

对于所有评测用例,输入的长度不超过 200000。

import java.util.Scanner;

public class Case6 {

    public static void main(String[] args) {
        char[] a = {'0', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S',
                'T', 'U', 'V', 'W', 'X', 'Y', 'Z'};
        Scanner in = new Scanner(System.in);
        String s = in.nextLine();

        char[] arr = s.toCharArray();
        for (int i = 1; i <= arr.length; i++) {

            if (arr[i - 1] <= '2' && arr[i] <= '6') {
                String s1 = arr[i - 1] + "" + arr[i];
                int t1 = Integer.parseInt(s1);
                System.out.print(a[t1]);
                i++;

                if (i == arr.length - 1 && arr[i - 1] > '2') {
                    int t3 = Integer.parseInt(arr[i] + "");
                    System.out.print(a[t3]);
                    break;
                }

            } else {
                String s2 = arr[i - 1] + "";
                int t2 = Integer.parseInt(s2);
                System.out.print(a[t2]);
            }
        }
    }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
题目描述: 给定一个字符串s,求出该字符串的最长重复子串长度。 输入格式: 第一行为一个整数n,表示字符串的长度。 第二行为一个字符串s。 输出格式: 输出一个整数,表示该字符串的最长重复子串长度。 样例输入: 6 ababab 样例输出: 3 算法1: (后缀数组) $O(nlog^2n)$ 我们可以将字符串的所有后缀排序,然后求相邻两个后缀的最长公共前缀,最后取所有公共前缀中的最大值即可。 具体来说,我们可以使用后缀数组来对字符串的所有后缀进行排序,然后使用倍增算法求出相邻两个后缀的最长公共前缀。 时间复杂度: - 后缀数组的构建时间复杂度为O(nlogn)。 - 最长公共前缀的计算时间复杂度为O(nlogn)。 因此,总时间复杂度为O(nlog^2n)。 C++ 代码 算法2: (哈希) $O(nlogn)$ 我们可以将字符串s拆分成多个子串,然后对每个子串进行哈希,最后使用二分查找的方式找到最长的重复子串。 具体来说,我们可以将字符串s拆分成多个子串,然后对每个子串进行哈希。哈希算法可以使用Rabin-Karp算法,时间复杂度为O(n)。 找到哈希值相同的两个子串后,我们可以使用二分查找来判断这两个子串的最长公共前缀的长度。二分查找的时间复杂度为O(logn)。 时间复杂度: - 哈希的时间复杂度为O(n)。 - 二分查找的时间复杂度为O(logn)。 因此,总时间复杂度为O(nlogn)。 C++ 代码 算法3: (Manacher算法) $O(n)$ Manacher算法是一种可以在线性时间内找到一个字符串的所有回文子串的算法。 该算法的核心思想是利用回文子串的对称性,来避免重复计算。具体来说,我们可以通过维护最右边的回文子串的右端点来避免重复计算。 时间复杂度: 该算法的时间复杂度为O(n)。 C++ 代码

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值