举例,输入fff,输出4095
方法1
#include<iostream>
#include<iomanip>
#include<cstring>
using namespace std;
int main()
{
char a[80];
cout << "请输入16进制字符串:" << endl;
cin.getline(a, 80);//输入字符串
char* p;
int k = strlen(a);//求出字符串长度
p = a+k-1;//因为要倒着计算,故要指向最后一位
int m = 1;
int szdecsum = 0;//记录十进制的结果
while (p>=a)//倒着计算,到最前面一个数结束
{
if (*p >= 'a' && *p <= 'f')
{
szdecsum += (int)(10 + *p - 'a')*m;
}
else if(*p >= '0' && *p <= '9')
{
szdecsum += (int)(*p - '0') * m;
}
m = m*16;//第一位是16的0次方,第二位是16的一次方....
p--;//自减即可以倒着计算每个十六进制字符对应的十进制值
}
cout << "转为十进制为:" << szdecsum;
return 0;
}
方法2
#include<iostream>
#include<iomanip>
#include<cstring>
using namespace std;
int main()
{
char hex[5], * p;
p = hex;
int a = 0;
cout << "请输入十六进制字符串(不超过4位)"<<endl;
cin.getline(hex, 5);
while (*p)
{ if (*p >= '0' && *p <= '9')
{
a = a * 16 + * p - '0';//这样就正好表示了10进制的某个数
}
else if (*p >= 'a' && *p <= 'f')
{
a = a * 16 + * p - 'a'+10;//这样表示10进制的某个十六进制数
} //*p-'a'是这个字母与字母a的相对距离,再+10即得该字母为什么
else if (*p >= 'A' && *p <= 'F')
{
a = a * 16 + * p - 'A'+10;
}
p++;
}
cout << a;
return 0;
}
因为大小写的字母a到f都可以表示十六进制的后7位,所以都要考虑到