今天有个来我们公司面试,要做机试题目,本来想让我帮忙看看来,结果我去看题目,发现写的时候麻烦点
最烦字符串的处理啦
题目是这样的:(1)输入一行字符串,格式是4 12 234 45 66,第一个数字是后边数字的个数
(2)输出类似这种形式“this char[]="0x34,0x22,0x44,0x77"
和同事商量后,同事给的思路是写一个切割函数,然后转化即可。我想了想,还有很多异常判断啊!
具体代码如下(未调试,明个测一把,肯定很多错误)
//切割函数
int split(const char *str, char **dest)
{
if(str[0] == '\0')
{
return -1;
}
int i = 0;
int num = 0;
int j = 0;
while(str[i] != '\0')
{
if(str[i] >= '0' && str[i] <= '9')
{
i++;
num++;
}
else if(str[i] == '')
{
memcpy(*(dest+j),str,num);
num = 0;
j++;
continue;
}
else
{
return -1;
}
}
**(dest+j+1)='\0'
return j;
}
//转化函数
void change(const char** src,int* temp, int j)
{
int temp[j+1];
for(int i = 0 ; i < j; i++)
{
temp[i] = atoi(*src+i);
}
temp[j+1] = '\0';
}
//main函数
void main()
{
char * str;
//输入一行字符串,测试
printf("输入一行字符串:");
scanf("%s",&str);
//切割字符串
int i = 0;
char **dest;
int *temp;
i = split(str, *dest);
change(*dest,temp,i);
//十六进制printf
}