轉自:http://wawlian.iteye.com/blog/1315133函數
問題1:講一個十進制數字的字符串表示轉換成對應的整數。舉例:將「1234」轉換成整數1234. C代碼 收藏代碼 /*將字符串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」是否出現均可以。 要解決這個問題,還須要一個將大寫字母轉換成小寫字母的工具函數: C代碼 收藏代碼 /*將大寫字母轉換成小寫字母*/ int tolower(int c) { if (c >= 'A' && c <= 'Z') { return c + 'a' - 'A'; } else { return c; } } 下面是轉換函數: 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; }