资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535
题目简析
公式:num = 0; num = num*16 + i(十六进制的每一位数对应的十进制数)
其他进制可效仿
数据范围:8位的十六进制数,long类型过不了最后一个测试数据,unsigned long就够用了。
代码如下
#include<iostream>
#include<string.h>
using namespace std;
int main(){
unsigned long sum = 0;
char a[9];
cin>>a;
if(strlen(a) == 1 && a[0] == '0'){
cout<<0;
}else{
for(int i = 0; i < strlen(a); i++){
if(a[i] >= '0' && a[i] <= '9'){
sum *= 16;
sum += a[i] - '0';
}else{
sum *= 16;
sum += a[i] - '7';
}
}
cout<<sum;
}
}