轉載地址:https://wawlian.iteye.com/blog/1315133
小程序一:
十進制數字的字符串表示轉換成對應的整數。例如:將“1234”轉換成整數1234。
1 /*將字符串s轉換成相應的整數*/ 2 int atoi(char s[]) 3 { 4 int i; 5 int n = 0; 6 for (i = 0; s[i] >= '0' && s[i] <= '9'; ++i) 7 { 8 n = 10 * n + (s[i] - '0'); 9 } 10 return n; 11 }
小程序二:
十六進制數的字符串轉換成對應的整數。所謂的十六進制數的字符串形式是指字符串只包含'0'-'9'或者'a'-'z'或者'A'-'Z'。
要解決這個問題,還需要一個將大寫字母轉換成小寫字母的工具函數。
1 int tolower(int c) 2 { 3 if (c >= 'A' && c <= 'Z') 4 { 5 return c + 'a' - 'A'; 6 } 7 else 8 { 9 return c; 10 } 11 } 12 13 int htoi(char s[]) 14 { 15 int i; 16 int n = 0; 17 if (s[0] == '0' && (s[1]=='x' || s[1]=='X')) 18 { 19 i = 2; 20 } 21 else 22 { 23 i = 0; 24 } 25 for (; (s[i] >= '0' && s[i] <= '9') || (s[i] >= 'a' && s[i] <= 'z') || (s[i] >='A' && s[i] <= 'Z');++i) 26 { 27 if (tolower(s[i]) > '9') 28 { 29 n = 16 * n + (10 + tolower(s[i]) - 'a'); 30 } 31 else 32 { 33 n = 16 * n + (tolower(s[i]) - '0'); 34 } 35 } 36 return n; 37 }