问题1:讲一个十进制数字的字符串表示转换成对应的整数。举例:将“1234”转换成整数1234.
- /*将字符串s转换成相应的整数*/
- intatoi(chars[])
- {
- inti;
- intn=0;
- for(i=0;s[i]>='0'&&s[i]<='9';++i)
- {
- n=10*n+(s[i]-'0');
- }
- returnn;
- }
问题2:将一个十六进制数的字符串表示形式转换成对应的整数。所谓的十六进制数的字符串形式是指字符串只包含'0'-'9'或者'a'-'z'或者'A'-'Z',前导“0x”或者“0X”是否出现都可以。
要解决这个问题,还需要一个将大写字母转换成小写字母的工具函数:
- /*将大写字母转换成小写字母*/
- inttolower(intc)
- {
- if(c>='A'&&c<='Z')
- {
- returnc+'a'-'A';
- }
- else
- {
- returnc;
- }
- }
下面是转换函数:
- //将十六进制的字符串转换成整数
- inthtoi(chars[])
- {
- inti;
- intn=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');
- }
- }
- returnn;
- }