问题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")) //判断是否有前导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;
- }