蓝桥杯 十六进制转化为十进制

问题描述
  从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
  注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。
样例输入
FFFF
样例输出
65535

#include

#include
#include
using namespace std;
int main()
{
    int i,j;
    long long  answer=0;  //在这卡了一晚上,上网看别人的代码才知道int型大小不够 !!!!!!!!
    char a[10];
    while(cin>>a)
    {
        answer=0;
        int n=strlen(a);
        for(i=n-1;i>=0;i--)
        {
            if(a[i]>='A'&&a[i]<='F')
            {
                answer+=(a[i]-'A'+10)*pow(16,n-i-1);
            }
            else
                {
                    answer+=(a[i]-48)*pow(16,n-i-1);     //a[i]为字符型 要减去0的ascii码48才是数字
                }
        }
        cout<    }
}

你可能感兴趣的:(水题)