我的代码就是这样!!
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 ");
}
}
答案 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()将字符串分解为标记/单词。