十六进制转十进制
资源限制
时间限制:1.0s 内存限制:512.0MB
问题描述
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535
思路:
十六进制的整数,从右到左的每一个数依次乘以 16 的 0 次方,16 的 1 次方,16 的 2 次方…,然后把每所有所得的数加在一起,就是要转换的十进制数。
完整代码:
#include<cstring>
#include<cmath>
#include<iostream>
using namespace std;
char s[100000];
int a[100000];
int main()
{
cin>>s;
int len=strlen(s);
long long sum=0;
for(int i=0; i<len; i++)
{
if(s[i]>='0'&&s[i]<='9')
{
a[i]=s[i]-'0';
}
else
{
a[i]=s[i]-'A'+10;
}
sum+=a[i]*pow(16,len-1-i);
}
cout<<sum<<endl;
return 0;
}
注:下面这个代码。蓝桥杯要求输入正数的十六进制数。所以这个代码可以无视,因为包含负数情况。
#include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
using namespace std;
char s[100000];
int a[100000];
int main()
{
cin>>s;
int len=strlen(s);
long long sum=0;
if(s[0]=='-') //当十六进制数为负数是
{
printf("-");
for(int i=1; i<len; i++)
{
if(s[i]>='0'&&s[i]<='9')
{
a[i]=s[i]-'0';
}
else
{
a[i]=s[i]-'A'+10;
}
sum+=a[i]*pow(16,len-1-i);
}
}
else //当16进制数为正数时
{
for(int i=0; i<len; i++)
{
if(s[i]>='0'&&s[i]<='9')
{
a[i]=s[i]-'0';
}
else
{
a[i]=s[i]-'A'+10;
}
sum+=a[i]*pow(16,len-1-i);
}
}
cout<<sum<<endl;
return 0;
}