- /*將字符串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')) //判斷是否有前導0x或者0X
- {
- 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;
- }