资源限制
内存限制:512.0MB C/C++时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s
问题描述
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535
代码实现
将十六进制数转换为十进制数,整体思路就是,根据十六进制的每一数位对应的16^j(16的j次方),再乘以每一数位的数即可。
其中可以将十六进制与十进制各个数字转换写成一个静态方法,以方便调用。
特别需要注意的一点是,由于问题描述中,输入“不超过8位的正的十六进制数字符串”,因此可能数字会非常大,需要保证选取long类型进行数字设定,使用int类型则会超出范围而出错。
import java.util.Scanner;
public class Main {
public static void main(String args[]) {
Scanner in = new Scanner(System.in);
char[] list = String.valueOf(in.nextLine()).toCharArray();
int size = list.length;
//先找到个位对应的数字
long result = findNum(list[size-1]);
//接着对更高数位的数进行计算(从十位按1依次往高位算起,每一数位i都对应的是16^i)
for(int i=1;i<size;i++) {
long a = 1;
int j = i;
//按照数位计算对应的是16的几次方
while(j!=0) {
a*=16;
j--;
}
//将对应数位的结果,加入result中
result+=a*findNum(list[size-1-i]);
}
System.out.println(result);
}
//编写一个十六进制各个数字表示形式,转换为十进制对应的数字的方法
public static int findNum(char number) {
char[] ch = {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
int r=-1;
for(int i=0;i<ch.length;i++) {
if(ch[i]==number) {
r = i;
break;
}
}
return r;
}
}