假定整数数列中的数不重复,并存放在数组中。给定程序MODII.C中函数fun的功能是:删除数列中值为x的元素。n中存放的是数列中元素的个数。 请改正程序中的错误,使它能得出正确结果。 注意:不要改动main函数,不得增行或删行,也不得更改程

admin2013-04-02  30

问题 假定整数数列中的数不重复,并存放在数组中。给定程序MODII.C中函数fun的功能是:删除数列中值为x的元素。n中存放的是数列中元素的个数。
    请改正程序中的错误,使它能得出正确结果。
    注意:不要改动main函数,不得增行或删行,也不得更改程序的结构。
#include
#define N 20
int fun(int *a,int n,int x)
{int p=0,i;
    a[n]=x;
    while(x!=a[p])
    p=p+1;
/**********found**********/
    if(P==n) return -1;
    else
    {for(i=p;i/**********found**********/
      a[i+1]=a;
      return n-1;
    }
}
main()
{int w[N]={-3,0,1,5,7,99,10,15,30,90},x,n,i;
   n=10;
   printf("The original data :\n");
   for(i=0;i);
   printf("\nInput x (to delete): "); scanf("%d",&x);
   printf("Delete : %d\n",x);
   n=fun(w,n,x);
   if (n==-1) printf("***Not be found!***\n\n");
   else
   {printf("The data after deleted:\n");
      for(i=0;i);printf("\n\n");
   }
}

选项

答案if(p==n) return -1; a[i]=a[i+1];

解析 (1)第一标识下“if(P==n) return -1;”中变量P没有定义,编译时会提示出错。根据题意,这里是判断p是否已经到了字符串的末尾,即是否存在值为x的元素,如果不存在则返回-1,故第一标识下应改为“if(p==n) return -1;”。
(2)“for(i=p;i;”循环语句实现的功能应该是p前面元素前移的操作,根据题意,删除数列中值为x的元素后,应该是后面的字符往前面移动,因此应该将“a[i+1]=a;”改为“a=a[i+1];”,即后一个元素值赋给前一个元素。
转载请注明原文地址:https://kaotiyun.com/show/KPJp777K
0

最新回复(0)