c++字符串题目

 


今天有个来我们公司面试,要做机试题目,本来想让我帮忙看看来,结果我去看题目,发现写的时候麻烦点
最烦字符串的处理啦
题目是这样的:(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
}


发布了35 篇原创文章 · 获赞 7 · 访问量 3万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章