字符串转换成十进制整数

5-1 字符串转换成十进制整数 (15分)

输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。
输入格式:

输入在一行中给出一个以#结束的非空字符串。
输出格式:

在一行中输出转换后的十进制数。题目保证输出在长整型范围内。
输入样例:

+-P-xf4+-1!#

输出样例:

-3905

think:我感觉这个题不难,只要把进制转换能懂了就OK了

#include 
#include 
#include 
#include 
char a[100010];
char b[100010];
int he(char s,int i,int len);
int main()
{
    int i,j;
    int x = 0;
    scanf("%s",a);
    int len = strlen(a);
    i = 0;
    j = 0;
    while(i < len)
    {
        if(x == 0&&j == 0&&a[i] == '-')
        {
            x = 1;
            i++;
        }
        if(a[i] >= '0'&&a[i] <= '9')
        {
            b[j] = a[i];
            j++;
            i++;
        }
        else if(a[i] >= 'a'&&a[i] <= 'f'||a[i] >= 'A'&&a[i] <= 'F')
        {
            b[j] = a[i];
            j++;
            i++;
        }
        else
            i++;
    }
    int sum = 0;
    int len1 = strlen(b);
    i = 0;
    int aa;
    while(i < len1)
    {
        aa = he(b[i],i,len1);
        sum+=aa;
        i++;
    }
    if(x == 1&&sum!=0)
        printf("-");
    printf("%d\n",sum);
    return 0;
}
int he(char s,int i,int len)
{
    if(s == '0')
        return 0*pow(16,(len-i-1));
    else if(s == '1')
        return 1*pow(16,(len-i-1));
    else if(s == '2')
        return 2*pow(16,(len-i-1));
    else if(s == '3')
        return 3*pow(16,(len-i-1));
    else if(s == '4')
        return 4*pow(16,(len-i-1));
    else if(s == '5')
        return 5*pow(16,(len-i-1));
    else if(s == '6')
        return 6*pow(16,(len-i-1));
    else if(s == '7')
        return 7*pow(16,(len-i-1));
    else if(s == '8')
        return 8*pow(16,(len-i-1));
    else if(s == '9')
        return 9*pow(16,(len-i-1));
    else if(s == 'a'||s == 'A')
        return 10*pow(16,(len-i-1));
    else if(s == 'b'||s == 'B')
        return 11*pow(16,(len-i-1));
    else if(s == 'c'||s == 'C')
        return 12*pow(16,(len-i-1));
    else if(s == 'd'||s == 'D')
        return 13*pow(16,(len-i-1));
    else if(s == 'e'||s == 'E')
        return 14*pow(16,(len-i-1));
    else if(s == 'f'||s == 'F')
        return 15*pow(16,(len-i-1));
}

你可能感兴趣的:(天梯赛模拟)