6、五键键盘的输出——华子机试必知必会

328 阅读2分钟

题目描述

有一个特殊的5键键盘,上面有 a,ctrl-c,ctrl-x,ctrl-v,ctrl-a五个键。
a 键在屏幕上输出一个字母 a;
ctrl-c将当前选择的字母复制到剪贴板;
ctrl-x将当前选择的 字母复制到剪贴板,并清空选择的字母;
ctrl-v将当前剪贴板里的字母输出到屏幕;
ctrl-a 选择当前屏幕上所有字母。

注意:
1、剪贴板初始为空,新的内容被复制到剪贴板时会覆盖原来的内容
2、当屏幕上没有字母时,ctrl-a无效
3、当没有选择字母时,ctrl-c和 ctrl-x无效
4、当有字母被选择时,a和ctrl-v这两个有输出功能的键会先清空选择的字母,再进行输出

给定一系列键盘输入,输出最终屏幕上字母的数量。

输入描述

输入为一行,为简化解析,用数字 12345代表 a,ctrl-c,ctrl-x,ctrl-v,ctrl-a五个键的输入,数字用空格分隔

输出描述

输出一个数字,为最终屏幕上字母的数量。

示例一

输入

111  

输出

3

示例二

输入

11111152111114

输出

11

题解

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String input = scanner.nextLine().trim();
        int result = calculateScreenLetters(input);
        System.out.println(result);
    }

    private static int calculateScreenLetters(String input) {
        int screenLetters = 0;
        int copyNum = 0;
        boolean isSelected = false;

        for (char c : input.toCharArray()) {
            //将字符c转换为对应的数字。(在ASCII码中,数字字符 '0' 到 '9' 对应的ASCII码是连续的,分别是 48 到 57。所以当我们将一个数字字符与字符 '0' 相减时,得到的结果就是该数字字符对应的整数值。)
            int num = c - '0';
            switch (num) {
                //在屏幕上输出一个字母 a
                case 1:
                    if (isSelected) {
                        screenLetters=0;
                        screenLetters++;
                        isSelected = false;
                    } else {
                        screenLetters++;
                    }
                    break;
                //ctrl-c
                case 2:
                    if (isSelected) {
                        copyNum=screenLetters;
                    }
                    break;
                //ctrl-x
                case 3:
                    if (isSelected) {
                        screenLetters=0;
                        copyNum=screenLetters;
                        isSelected = false;
                    }
                    break;
                //ctrl-v
                case 4:
                    if (isSelected) {
                        screenLetters += copyNum;
                    }
                    break;
                //ctrl-a
                case 5:
                    isSelected = true;
                    break;
                default:
                    break;
            }
        }
        return screenLetters;
    }