如何使字符串明智(以便以后我可以反转)存储在数组??在C.

时间:2010-11-21 06:32:47

标签: c string

我的代码就是这样!!

int i=0,j=0,k=0;
 char *a[20];
 int count=0;
 for(i=0;i<20;i++)
    {
       a[i] = malloc(50 * sizeof(char));
    }
   i=0; 
 while(*(p+i)!='\n')
 {
  int k=0; 
   while(*(p+i)!=' ')
     {
    *(a[j]+k)=*(p+i);
    i++;
    k++;
   }
   *(a[j]+k)='\0';
                 i++;
          j++;
 }
 printf("\n Count%d",j);
 count=j;
 for(j=0;j<count;j++)
 {
  printf("%s",a[j]);
    printf("\n \n ");
  }
}  

2 个答案:

答案 0 :(得分:2)

'更好'比strtok&amp; Co见下文:

int strsplit(const char *s,char ***l,char t)
{
  int r=0;
  while( strchr(s,t) )
  {
    *l=realloc(*l,++r*sizeof*l);
    memcpy((*l)[r-1]=calloc(1,strchr(s,t)-s+1),s,strchr(s,t)-s);
    s=strchr(s,t)+1;
  }
  *l=realloc(*l,++r*sizeof*l);
  memcpy((*l)[r-1]=calloc(1,strlen(s)+1),s,strlen(s));
  return r;
}

int main()
{
    char **l=0,*x="1;2;;4";
    int i,r=strsplit(x,&l,';');
    for(i=0;i<r;++i)
    {
      puts(l[i]);
      free(l[i]);
    }
    free(l);
    return 0;
}

更好,因为字符串可以是const,它在多线程中工作,空工作不会被忽略。

答案 1 :(得分:0)

您没有说明您的代码是否真的有效。有没有问题,或者您只是要求对您的代码发表评论?如果有超过49个字符的单词,您的代码将失败。

您可以使用库函数strtok()将字符串分解为标记/单词。