C语言练习10---倾情巨制My_atoi的实现

My_atoi的函数要求

1. "123456"  转化为整形值 123456

2."     123456",跳过前面的空格转化为整型值123456,如果在字符串中间遇见空格则停止转换,例如"    123  456"将其转换为123返回

3."+123456",返回123456

4."-123456" ,返回-123456

5."0b123"或者"0B123"将其以二进制转换为十进制整形值

6."0123"将其以八进制转换为十进制整形值

7."0x123"或者"0X123"将其以十六进制转换为十进制整形值

8.考虑到输入错误的情况---比如将0 输成'o'或'O',1 输成 'l' 或 'i'

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <ctype.h>

int My_Dec(char*str)            //十进制字符串转化为整型
{
	assert(str != NULL);
	int sum = 0;
	while (*str!='\0')               
	{
		if (*str == 'o' || *str == 'O')
		{
			sum = sum * 10;
			str++;
		}
		else if (*str == 'l' || *str == 'i')
		{
			sum = sum * 10 + 1;
			str++;
		}
		else if ('0' <= *str && *str <= '9')
		{
			sum = sum * 10 + *str - '0';
			str++;
		}
		else
		{
			return sum;
		}
		
	}
	return sum;
}

int My_Bin(char*str)            //二进制字符串转化为整型
{
	assert(str != NULL);
	int sum = 0;
	while (*str != '\0')              
	{
		if (*str == 'o' || *str == 'O')
		{
			sum = sum * 2;
			str++;
		}
		else if (*str == 'l' || *str == 'i')
		{
			sum = sum * 2 + 1;
			str++;
		}
		else if ('0' == *str || *str == '1')
		{
			sum = sum * 2 + *str - '0';
			str++;
		}
		else
		{
			return sum;
		}
	}
	return sum;
}

int My_Oct(char*str)              //八进制字符串转化整型
{
	assert(str != NULL);
	int sum = 0;
	while (*str != '\0')               
	{
		if (*str == 'o' || *str == 'O')
		{
			sum = sum * 8;
			str++;
		}
		else if (*str == 'l' || *str == 'i')
		{
			sum = sum * 8 + 1;
			str++;
		}
		else if ('0' <= *str && *str <= '7')
		{
			sum = sum * 8 + *str - '0';
			str++;
		}
		else
		{
			return sum;
		}
	}
	return sum;
}

int My_Hex(char*str)    //十六进制字符串转化整型
{
	assert(str != NULL);
	int sum = 0;
	while (isxdigit(*str) || *str == 'l' || *str == 'i' || *str == 'o' || *str == 'O')
	{
		if (isalpha(*str) && *str != 'l'&&*str != 'i' && *str != 'o' && *str != 'O')   //字母
		{
			sum = sum * 16 + tolower(*str) - 'a'+10;
			str++;
		}
		else if (*str == 'l' || *str == 'i') 
		{
			sum = sum * 16 + 1;
			str++;
		}
		else if (*str == 'o' || *str == 'O')
		{
			sum = sum * 16 ;
			str++;
		}
		else  
		{
			sum = sum * 16 + *str - '0';
			str++;
		}
	}
	return sum;
}

int My_atoi(char*str)
{
	assert(str != NULL&&*str != '\0');
	while (*str == ' ')
	{
		str++;
	}
	int tag = 0;   //0正   1负
	if (*str == '-')
	{
		str++;
		tag = 1;
	}
	if (*str == '+')
	{
		str++;
	}
	int sum = 0;
	if (*str == '0' || *str == 'o' || *str == 'O')
	{
		if (*(str + 1) == 'b' || *(str + 1) == 'B')
		{
			str += 2;
			sum = My_Oct(str);
		}
		else if (*(str + 1) == 'x' || *(str + 1) == 'X')
		{
			str += 2;
			sum = My_Hex(str);
		}
		else
		{
			str++;
			sum = My_Bin(str);
		}
	}
	else 
	{
		sum = My_Dec(str);
	}

	if (tag)
	{
		sum = -sum;
	}
	return sum;
}

int main()
{
	const char* str[] = { 
		"123", "   1234", "+lo2345", "123.45", " -7o89", "oB1234", "oxO1Oo23456","lllo3O56",
	     "011111","01110111"};
	for (int i = 0; i < sizeof(str) / sizeof(str[0]); i++)
	{
		printf("%s=>%d\n", str[i], My_atoi(str[i]));
	}
	system("pause");
	return 0;
}

 

如果是二进制请以0开头,不然没法区分二进制与十进制!!! 

 那里有问题,请随意评论,我一定认真检查~~~

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值