【华为OD题库-065】一种字符串压缩表示的解压-java

题目

有一种简易压缩算法∶针对全部为小写英文字母组成的字符串,将其中连续超过两个相同字母的部分压缩为连续个数加该字母,其他部分保持原样不变。例如字符串aabbccd经过压缩变成字符串3abb4cd请您编写解压函数,根据输入的字符串,判断其是否为合法压缩过的字符串。若输入合法则输出解压缩后的字符串,否则输出字符串! error来报告错误
输入描述:
输入一行,为一个ASCII字符串长度不超过100字符。用例保证输出的字符串长度也不会超过100字符串
输出描述:
若判断输入为合法的经过压缩后的字符串则输出压缩前的字符串;若输入不合法则输出字符串! error
示例1:
输入:
4dff
输出
ddddff
说明
4d扩展为dddd,故解压后的字符串为ddddff.

示例2
输入:
2dff
输出
! error
说明
两个d不需要压缩,故输入不合法
示例3:
输入:
4a@A
输出
! error
说明
全部由小写英文字母组成的字符串压缩后不会出现特殊字符@和大写字母A,故输入不合法。

思路

简单字符串处理题目,遍历输入,根据当前字符类型判断:

  1. 如果当前字符是数字,则继续查找直到当前指向的不是数字(比如10a),计算其数字的值num,然后在结果中加入num个当前字符,注意异常情况:

3a4: 数字后没有字符
3a4D:数字后的字符非小写字母
2a3b:数字值小于等于2
3a4a:加入的字符等于上次加入的字符

  1. 如果当前字符是小写字母,直接加入结果,注意异常情况:

aaa3b或者3aa3b,在加入当前单个字符之前,如果上次加入的就是该字符,并且次数超过两个,那么应该判断为非法。可以直接取当前加入的字符串的最后两位来比较

  1. 否则返回"!error"

题解

package hwod;

import java.util.Scanner;

public class CompressingStr {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String str = sc.nextLine();
        System.out.println(compressingStr(str));
    }

    private static String compressingStr(String str) {
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < str.length(); i++) {
            if (Character.isDigit(str.charAt(i))) {
                int num = str.charAt(i) - '0';
                i = i + 1;
                //直到i不是数字为止
                while (i < str.length() && Character.isDigit(str.charAt(i))) {
                    num = num * 10 + (str.charAt(i) - '0');
                    i++;
                }
                if (i >= str.length()  //3a4
                        || !Character.isLowerCase(str.charAt(i)) //3a4D
                        || num <= 2 //2a3b
                        || (sb.length() != 0 && str.charAt(i) == sb.toString().charAt(sb.length() - 1))) //3a4a
                    return "!error";

                for (int j = 0; j < num; j++) {
                    sb.append(str.charAt(i));
                }
            } else if (Character.isLowerCase(str.charAt(i))) {
                //aaa3b  3aa3b
                if (sb.length() >= 2 && sb.toString().substring(sb.length() - 2).equals("" + str.charAt(i) + str.charAt(i)))
                    return "!error";
                sb.append(str.charAt(i));
            } else {
                return "!error";
            }
        }
        return sb.toString();
    }
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

说明

本专栏所有文章均为原创,欢迎转载,请注明文章出处:https://blog.csdn.net/qq_31076523/article/details/134176793。百度和各类采集站皆不可信,搜索请谨慎鉴别。技术类文章一般都有时效性,本人习惯不定期对自己的博文进行修正和更新,因此请访问出处以查看本文的最新版本。

  • 12
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
字符串化繁为简是指将复杂的问题或情况转化为简单的字符串处理。在Java语言中,可以通过字符串的各种方法和特性来实现。 首先,我们可以使用字符串的split()方法将一个字符串按照指定的分隔符分割成一个字符串数组。这个方法很实用,可以将一个较长的字符串按照指定的标记分割成若干子字符串,方便后续的处理。 其次,我们可以使用字符串的replace()方法来替换字符串中的指定字符或子串。通过这个方法,我们可以将一个字符串中的复杂部分替换为简单的内容,进而简化问题。 另外,字符串的indexOf()方法可以用来查找某个字符或子串在原字符串中的位置。通过这个方法,我们可以找到需要处理的复杂部分的位置,并进行相应的处理。 此外,字符串的length()方法可以获取字符串的长度,而charAt()方法可以获取指定位置的字符。利用这两个方法,我们可以遍历字符串,对每个字符进行逐个处理。 最后,我们还可以使用字符串的concat()方法将多个字符串连接起来成为一个字符串。这在某些情况下非常方便,可以将多个简单字符串组合成一个复杂字符串或者将一个复杂字符串拆分成多个简单字符串。 总之,通过利用Java字符串的各种方法和特性,我们可以将复杂的问题或情况转化为简单的字符串处理,达到字符串化繁为简的效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值