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

news/2024/7/20 17:40:23 标签: 华为od, 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"

题解

java">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),查看当前专栏更新的所有题目。


http://www.niftyadmin.cn/n/5241090.html

相关文章

【电子取证篇】汽车取证数据提取与汽车取证实例浅析(附标准下载)

【电子取证篇】汽车取证数据提取与汽车取证实例浅析&#xff08;附标准下载&#xff09; 关键词&#xff1a;汽车取证&#xff0c;车速鉴定、声像资料鉴定、汽车EDR提取分析 汽车EDR一般记录车辆碰撞前后的数秒&#xff08;5s左右&#xff09;相关数据&#xff0c;包括车辆速…

python笔记:dtaidistance

1 介绍 用于DTW的库纯Python实现和更快的C语言实现 2 DTW举例 2.1 绘制warping 路径 from dtaidistance import dtw from dtaidistance import dtw_visualisation as dtwvis import numpy as np import matplotlib.pyplot as plts1 np.array([0., 0, 1, 2, 1, 0, 1, 0, 0…

前端食堂技术周刊第 107 期:技术播客节、Deno Cron、FEDAY、XState v5、Electron 2023 生态系统回顾

美味值&#xff1a;&#x1f31f;&#x1f31f;&#x1f31f;&#x1f31f;&#x1f31f; 口味&#xff1a;烤椰拿铁 食堂技术周刊仓库地址&#xff1a;https://github.com/Geekhyt/weekly 大家好&#xff0c;我是童欧巴。欢迎来到前端食堂技术周刊&#xff0c;我们先来看下…

JavaScript 之数组

数组之间 合并问题 1 concat()方法 concat()方法可以将多个数组合并成一个新的数组。 const array1[1,2,3] const array2[4,5,6] const arrayListarray.concat(array2) //打印[1,2,3,4,5,6] 2 拓展运算符 拓展运算符是将一个数组拆分为单个元素&#xff0c;并将其添加到另…

【华为OD题库-066】冠亚军排名-java

题目 2012伦敦奥运会即将到来&#xff0c;大家都非常关注奖牌榜的情况&#xff0c;现在我们假设奖牌榜的排名规则如下. 1.首先gold medal数量多的排在前面 2.其次silver medal数量多的排在前面 3.然后bronze medal数量多的排在前面 4.若以上三个条件仍无法区分名次&#xff0c;…

Http中post和get

get产生一个tcp数据包&#xff0c;服务器只响应一次&#xff0c;而post请求服务器会响应两次&#xff08;第一次发送请求头响应100&#xff0c;再次响应返回200&#xff0c;成功

CSS基础概念之选择器类型

CSS选择器类型 选择器表示元素在树结构中的特定模式。选择器(selector)术语指的是&#xff0c;简单选择器(simple selector)&#xff0c;复合选择器(compound selector)&#xff0c;复杂选择器(complex selector)&#xff0c;或者选择器列表(selector list)。选择器的主题是任…

SI24R03 高度集成低功耗SOC 2.4G 收发一体芯片

今天给大家介绍一款Soc 2.4G 收发一体模块-SI24R03 Si24R03是一款高度集成的低功耗无线SOC芯片&#xff0c;芯片为QFN32 5x5mm封装&#xff0c;集成了资源丰富的MCU内核与2.4G收发器模块&#xff0c;最低功耗可达1.6uA&#xff0c;极少外围器件&#xff0c;大幅降低系统应用成本…