1. 程式人生 > >C語言將字串轉換成對應的數字(十進位制、十六進位制)

C語言將字串轉換成對應的數字(十進位制、十六進位制)

問題1:講一個十進位制數字的字串表示轉換成對應的整數。舉例:將“1234”轉換成整數1234.

/*將字串s轉換成相應的整數*/  
int atoi(char s[])  
{  
    int i = 0;  
    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 = 0;  
    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;  
}  

本文轉自:

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