在进行转化之前我们需要先了解这样几点:
1.数字0~9的的值,即为0到9,然后10为’a’。
2.转化为十进制数就是将上面的这个值乘上16。
下面是进行转化的代码:
int i;
for (i = n; i >= 0; --i)
if (a[i] >= '0' && a[i] <= '9')
sum += (a[i] - '0') * pow(16, n - i);
else if (a[i] >= 'A' && a[i] <= 'F')
sum += (a[i] - 'A' + 10) * pow(16,n - i);
else
sum += (a[i] - 'a' + 10) * pow(16, n - i);
转化的情况有以下三种:
1.该字符为0~9的字符,便可以将该数字-‘0’,使其变为我上面提到的那个值,在乘上16的多少次方即可。
2.该字符为’A’~‘F’的字符,将该字符-‘A’后加上10即可,因为直接减去10是将该字符转化到了数字0到9,还需加上10变为十进制的’A’。
3.该字符为’a’~'f’时同2理。