【问题描述】
三月八日,小明买了台新车。但很快小明发现汽车的里程表有问题:里程表上每一位都不显示数字3和数字8,也就是说直接从数字2跳到数字4,直接从数字7跳到数字9。小明纳闷:这车到底行驶里程是多少。
现在,小明向你求助:根据里程表显示的数字,给出真实的行驶里程。
【输入形式】
输入有多组测试数据。
输入第一行正整数T,表示有多少组测试数据。
后面有T行,每行一个非负整数,表示里程表显示数字,里面不含有数字3和8。该数字不超过10位。
40%的测试数据组数T 10≤T≤ 102;
30%的测试数据组数T 102≤T≤ 103;
20%的测试数据组数T 103≤T≤ 104;
10%的测试数据组数T 104≤T≤ 105;
【输出形式】
对于每组测试数据,输出一个整数占一行:真实的行程里程。
【样例输入】
6
0
1
12
159
111224459
124567976
【样例输出】
0
1
10
103
19212007
21913077
分析思路:
第一步先将错误的里程数字修改正确(将9减二改为7,将4 ~ 7减一改为3 ~ 6),此时里程表的数字相当于八进制表示,接下来就是将八进制数转换为十进制数。
import java.util.Scanner;
public class 错误的里程表 {
static Scanner sc = new Scanner(System.in);
public static void method1() {
int num = sc.nextInt();
String str[] = new String[num];
for (int i = 0; i < num; i++) {
str[i] = sc.next();
char[] chars = str[i].toCharArray();
for (int j = 0; j < chars.length; j++) {
if (chars[j] == '9') {
chars[j] = '7';
} else if (chars[j] - '3' > 0) {
chars[j]--;
}
}
int k, sum = 0;
for (k = chars.length - 1; k >= 0 ; k--) {
sum += (chars[k] - '0') * Math.pow(8, chars.length - 1 - k);
}
System.out.println(sum);
}
}
public static void method2() {
int n = sc.nextInt();
for (int i = 0; i < n; i++) {
int sum = 0;
int num = sc.nextInt();
for (int j = 0; num != 0; j++) {
int a = num % 10;
if (a > 3 && a < 8) {
a--;
} else if (a > 8) {
a = a -2;
}
sum += a * Math.pow(8, j);
num /= 10;
}
System.out.println(sum);
}
}
public static void main(String[] args) {
method2();
}
}