所有注释代码为调试过程中需要的,为调试方便,暂不删除
#include <iostream>
#include <string>
#define N 8 //默认定义十六进制长度最大为8位
using namespace std;
int fun(int a){ //定义一个函数,简单说就是求16的a次幂 ,为后面与系数想乘
int sum=1;
for(int i=0;i<a;i++){
sum=sum*16;
}
// cout<<sum<<" ";
return sum;
}
int main(int argc, char** argv) {
string str; //定义一个字符串,用一个字符串来接受用户输入的十六进制数
cin>>str;
int sum=0; //用来表示最后十六进制转为十进制的结果
int a[N]; //用一个八位的数组来将字符串的每一位取出来,为后面计算做准备
for(int i=0;i<8;i++){
// cout<<"*"<<str[i];
a[i]=(int)str[i]; //将字符串的每一位取出来并强制转换为整形
//
// cout<<"^^"<<a[i]<<"^^";
if(48<=a[i]&&a[i]<=57){ //0~9的ascil码值为48~57,从字符转为整形后用ascil码值表示,做运算前要先把他转为数字,简单的减去48即可
a[i]=a[i]-48;
}
else{
switch(a[i]){ //十六进制有A,B,C,D,E,F,也需要转换,这里我们简单用switch,用户的十六进制输入错误暂时不做判断;
case 65:a[i]=10;break;
case 66:a[i]=11;break;
case 67:a[i]=12;break;
case 68:a[i]=13;break;
case 69:a[i]=14;break;
case 70:a[i]=15;break;
}
}
sum=sum+a[i]*fun(N-i-1); //a[i]是系数,dun(N-i-1)是幂次方,累加即得结果
}
cout<<endl;
//for(int i=0;i<8;i++){
// cout<<a[i]<<" ";
//}
cout<<sum;
return 0;
}
#include <string>
#define N 8 //默认定义十六进制长度最大为8位
using namespace std;
int fun(int a){ //定义一个函数,简单说就是求16的a次幂 ,为后面与系数想乘
int sum=1;
for(int i=0;i<a;i++){
sum=sum*16;
}
// cout<<sum<<" ";
return sum;
}
int main(int argc, char** argv) {
string str; //定义一个字符串,用一个字符串来接受用户输入的十六进制数
cin>>str;
int sum=0; //用来表示最后十六进制转为十进制的结果
int a[N]; //用一个八位的数组来将字符串的每一位取出来,为后面计算做准备
for(int i=0;i<8;i++){
// cout<<"*"<<str[i];
a[i]=(int)str[i]; //将字符串的每一位取出来并强制转换为整形
//
// cout<<"^^"<<a[i]<<"^^";
if(48<=a[i]&&a[i]<=57){ //0~9的ascil码值为48~57,从字符转为整形后用ascil码值表示,做运算前要先把他转为数字,简单的减去48即可
a[i]=a[i]-48;
}
else{
switch(a[i]){ //十六进制有A,B,C,D,E,F,也需要转换,这里我们简单用switch,用户的十六进制输入错误暂时不做判断;
case 65:a[i]=10;break;
case 66:a[i]=11;break;
case 67:a[i]=12;break;
case 68:a[i]=13;break;
case 69:a[i]=14;break;
case 70:a[i]=15;break;
}
}
sum=sum+a[i]*fun(N-i-1); //a[i]是系数,dun(N-i-1)是幂次方,累加即得结果
}
cout<<endl;
//for(int i=0;i<8;i++){
// cout<<a[i]<<" ";
//}
cout<<sum;
return 0;
}