问题描述
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s1,s2;//s1表示十六进制,s2表示二进制
s2="";
cin>>s1;
for(int j=0;j<s1.length();j++){
switch(s1[j])
{
case '0':s2+="0000";break;
case '1':s2+="0001";break;
case '2':s2+="0010";break;
case '3':s2+="0011";break;
case '4':s2+="0100";break;
case '5':s2+="0101";break;
case '6':s2+="0110";break;
case '7':s2+="0111";break;
case '8':s2+="1000";break;
case '9':s2+="1001";break;
case 'A':s2+="1010";break;
case 'B':s2+="1011";break;
case 'C':s2+="1100";break;
case 'D':s2+="1101";break;
case 'E':s2+="1110";break;
case 'F':s2+="1111";break;
default:break;
}
}
long long p=0,sum=1;
for(int s=0,k=s2.length()-1;k>=0;k--,s++){
for(int m=0;m<s;m++){
sum*=2;
}
p+=(s2[k]-'0')*sum;
sum=1;
}
cout<<p;
return 0;
}
该代码片段展示了一个C++程序,用于将用户输入的不超过8位的正十六进制数字符串转换成对应的十进制数值。程序通过逐位解析并转换十六进制字符到二进制,最后计算出十进制结果。
780





