题目描述
有一个特殊的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;
}