解题思路:
注意事项:
参考代码:
import java.util.Scanner; public class Main{ public static void main(String[] args) { // 小明有一串很长的英文字母,可能包含大写和小写。 在这串字母中,有很多连续的是重复的。小明想了一个办法将这串字母表达得更短:将连续的几个相同字母写成字母 + 出现次数的形式。 // 例如,连续的 5 个 a ,即 aaaaa ,小明可以简写成 a5 (也可能简写成 a4a 、 aa3a 等)。 // 对于这个例子:HHHellllloo ,小明可以简写成 H3el5o2 。为了方便表达,小明不会将连续的超过 9 个相同的字符写成简写的形式。 // 现在给出简写后的字符串,请帮助小明还原成原来的串。 Scanner sc = new Scanner(System.in); String str = sc.next(); for (int i = 0; i < str.length(); i++) { if(str.charAt(i) >= '0' && str.charAt(i) <= '9') { // 判断当前的字符是否是数字 // 循环当前数字的次数减一,因为下面的else是把字符串的所有字符输出一遍 for (int j = 0; j < str.charAt(i) - '0' - 1; j++) { System.out.print(str.charAt(i-1)); // 输出前面一个字符 } }else { System.out.print(str.charAt(i)); } } } }
0.0分
0 人评分