给定一个字符串求其对应的十六进制、八进制、十进制的值

static int to_Hex(const char* str)//判断16进制
{
	//0123456789abcdefABCDEF
	int sum = 0;
	while (isxdigit(*str))
	{
		if (isdigit(*str))
		{
			sum = sum * 16 + *str - '0';
		}
		else
		{
			tolower(*str);//全部转换成小写字母
			sum = sum * 16 + *str - 'a' + 10;
		}

		str++;
	}

	return sum;
}

static int to_Oct(const char* str)//判断是否为八进制
{
	//01234567
	int sum = 0;
	while (isdigit(*str) && *str != '8' && *str != '9')
	{
		sum = sum * 8 + *str - '0';
		str++;
	}

	return sum;
}
static int to_Dec(const char* str)//判断是否为10进制
{
	//0123456789
	int sum = 0;
	while (isdigit(*str))
	{
		sum = sum * 10 + *str - '0';
		str++;
	}
	return sum;
}
int My_atoi(const char* str)//判断正负号、空格
{
	//assert
	int tmp = 1;//正负标记
	int sum = 0;
	while (isspace(*str))
	{
		str++;
	}
	if (*str == '-')
	{
		tmp = -tmp;
		str++;
	}
	if (*str == '+')
	{
		str++;
	}
	if (*str == '0')//首地址为0
	{
		if (*(str + 1) == 'x' || *(str + 1) == 'X')//第二个元素是否为X和x
		{
			sum = to_Hex(str + 2);//十六进制
		}
		else
		{
			sum = to_Oct(str + 1);//八进制
		}
	}
	else
	{
		sum = to_Dec(str);//返回十进制
	}

	return sum * tmp;
}
int main()
{
	const char *str1 = "   -0x1a";
	//const char *str2 = "   -0123";
    //const char* str3 = "   123a";
	int tmp1 = My_atoi(str1);
	printf("%d\n", tmp1);
	return 0;
}

atoi:只能10进制
strtol:将字符串转换为长整型(任何进制)
        第一个参数:字符串开始地址  
        第二个参数:二级指针,返回字符串解析时停下来的位置  
        第三个参数:X进制

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值