字符串转换成对应十进制、十六进制数

问题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;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值