char *fun(char *s)
{ int i, j, k, n; char *p, *t;
n=strlen(s)+1;为什么要加一
t=(char*)malloc(n*sizeof(char));
p=(char*)malloc(n*sizeof(char));
j=0; k=0;
for(i=0; i<n; i++)
{ if(((s[i]>='a')&&(s[i]<='z'))||((s[i]>='A')&&(s[i]<='Z'))) {
/**********found**********/
t[j]=s[i]; j++;}j++之后,在原来遍历的基础上加一,所以要t[j+i]=p[i]
else
{ p[k]=s[i]; k++; }k也在原来的基础上加一,即有k个非字母,j个字母,非字母包含‘\0’
}
/**********found**********/
for(i=0; i<k; i++) t[j+i]=p[i];这里的循环多了一个啊
/**********found**********/
t[j+k]=0;
return t;