依次遍历数组,找到该元素后,数组后面所有元素前移,并且元素个数减一,最后重新输出该数组即可。
参考代码:
#include
int main() {
int n=10,i,j,x,a[10]={0,1,2,3,4,5,5,6,7,8};
scanf("%d",&x);
for(i=0;i<10;i++){
if(a[i]==x){
for(j=i;j+1<10;j++)
a[j]=a[j+1];
n--;
i--;
}
}
for(i=0;iprintf("%d ",a[i]);
return 0;
}
/*
运行结果:例如删除数字a{0,1,2,3,4,5,5,6,7,8}中的5
5
0 1 2 3 4 6 7 8
*/
//数组中被删除的数用-1代替。。
#include"stdio.h"
void main()
{
int i,a[10]={11,3,2,65,3,6,8,2,3,5},del;
printf("删除前的数组:");
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n输入要删除的数: ");
scanf("%d",&del);
for(i=0;i<10;i++)
if(a[i]==del)a[i]=-1;
printf("删除后的数组:");
for(i=0;i<10;i++)
printf("%d ",a[i]);
printf("\n");
}
#include"stdio.h"
main()
{
int i,a[10]={11,3,18,65,3,6,8,2,3,5},del;
scanf("%d",&del);
for(i=0;i<10;i++)
{
if(a[i]!=del)
printf("%d\n",a[i]);
}
}