问题描述
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入:
FFFF
样例输出:
65535
#include <bits/stdc++.h>
using namespace std;
int main(){
string s1,s2;
cin>>s1;
int ans=0;
for(int i=0;i<s1.length();i++){
if(s1[i]>='0'&&s1[i]<='9')
ans+=((s1[i]-'0')*pow(16,s1.length()-i-1));
else
ans+=(s1[i]-'A'+10)*pow(16,s1.length()-i-1);
}
cout<<ans<<endl;
return 0;
}
方法二不能过题
#include <bits/stdc++.h>
using namespace std;
int main(){
string s1,s2;
cin>>s1;
for(int i=0;i<s1.length();i++){
switch (s1[i]) {
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;
}
}
int temp=0;
for(int i=0;i<s2.length();i++){
temp+=((s2[i]-'0')*pow(2, s2.length()-i-1));
}
cout<<temp<<endl;
return 0;
}