问题描述
从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。(16的8次方=4 294 967 296,要用long long,不仅sum,count也要)count的设计也比较巧妙,count=1 count*=16
注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535
#include<iostream>
#include<string>
using namespace std;
int main() {
string s;
cin>>s;
long long t=0;
long long count=1;
for(int i=s.length()-1; i>=0; i--) {
if(s[i]-'0'>=0&&s[i]-'0'<=9)
t=t+(s[i]-'0')*count;
else
t=t+(s[i]-'A'+10)*count;
count*=16;
}
printf("%I64d\n",t);
return 0;
}