有几个问题
飘落的共和国旗 人气新星 2016-08-24 11:48:34
1075 8 0

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;


问题来自: 填空题真题

共 8 个回答

    qqq 资深元老 助教 3207天前

    n=strlen(s)+1是因为strlen函数不包括字符串最后的结束符'\0',加上1之后才能让n正好等于原字符串的长度。

    至于你下面提到的多了一个循环。。并不是很懂你的意思,整个代码的意思是,将原字符串中的字母全都放进指针t所指内存空间,非字母放进指针p所指内存空间,然后将p里的非字母连在t的字母后面,最后返回t,这样就能将处理后的字符串首地址返回到主函数中。

    飘落的共和国旗 人气新星 3207天前

    回复 qqq:我的意思是说for(i=0; i<k; i++)  t[j+i]=p[i]这里的截止条件是不是i<k-1啊,因为'\0'是非字母字符,包含在k个字符之中了

    qqq 资深元老 助教 3207天前

    回复 飘落的共和国旗:那你改成k-1之后能运行出正确答案么?

    飘落的共和国旗 人气新星 3207天前

    回复 qqq:能,就是结尾多一个?

    qqq 资深元老 助教 3207天前

    回复 飘落的共和国旗:结尾多一个问号?

    飘落的共和国旗 人气新星 3207天前

    回复 qqq:嗯

    qqq 资深元老 助教 3207天前

    嗯。。不好意思,到现在才回复。

    其实你的想法是对的,不过当for(i=0; i<k; i++)  t[j+i]=p[i];中的循环条件改成k-1之后,下面的t[j+k]=0;也要改成t[j+k-1]=0才对,你说是不是?

    飘落的共和国旗 人气新星 3207天前

    回复 qqq:嗯,对

您还没有登录,所以不能回复该问题
我要回复

  • 0

    点赞

  • 扫一扫分享朋友圈

    二维码

  • 分享

相关问题