xingboy

转自:http://wawlian.iteye.com/blog/1315133

1.一个十进制数字的字符串表示转换成对应的整数。举例:将“1234”转换成整数1234

/*将字符串s转换成相应的整数*/  
int atoi(char s[])  
{  
    int i;  
    int n = 0;  
    for (i = 0; s[i] >= \'0\' && s[i] <= \'9\'; ++i)  
    {  
        n = 10 * n + (s[i] - \'0\');  
    }  
    return n;  
}

2、将一个十六进制数的字符串表示形式转换成对应的整数。所谓的十六进制数的字符串形式是指字符串只包含\'0\'-\'9\'或者\'a\'-\'z\'或者\'A\'-\'Z\',前导“0x”或者“0X”是否出现都可以。 要解决这个问题,还需要一个将大写字母转换成小写字母的工具函数:

/*将大写字母转换成小写字母*/  
int tolower(int c)  
{  
    if (c >= \'A\' && c <= \'Z\')  
    {  
        return c + \'a\' - \'A\';  
    }  
    else  
    {  
        return c;  
    }  
} 
//将十六进制的字符串转换成整数  
int htoi(char s[])  
{  
    int i;  
    int n = 0;  
    if (s[0] == \'0\' && (s[1]==\'x\' || s[1]==\'X\'))  
    {  
        i = 2;  
    }  
    else  
    {  
        i = 0;  
    }  
    for (; (s[i] >= \'0\' && s[i] <= \'9\') || (s[i] >= \'a\' && s[i] <= \'z\') || (s[i] >=\'A\' && s[i] <= \'Z\');++i)  
    {  
        if (tolower(s[i]) > \'9\')  
        {  
            n = 16 * n + (10 + tolower(s[i]) - \'a\');  
        }  
        else  
        {  
            n = 16 * n + (tolower(s[i]) - \'0\');  
        }  
    }  
    return n;  
} 

 

分类:

技术点:

相关文章: