int b;
int a[5] = { 1, 2, 3, 4, 5 };
scanf_s("%d",&b);
int r = 0;
int i;
for ( i = 0; i<5; i++){
if (b == a[i]){//要删除的数据
a[i] = r;
}
else{
printf("%d\n",a[i]);
}
}//这样的话确实能删除一个数,但是如果我真的想把数值0肤赋值给数组中的元素呢?怎么办?
int b;
int a[5] = { 1, 2, 3, 4, 5 };
scanf_s("%d",&b);
int r = 0;
int i;
for ( i = 0; i<5; i++){
if (b == a[i]){//要删除的数据
a[i] = r;
}
else{
printf("%d\n",a[i]);
}
}//这样的话确实能删除一个数,但是如果我真的想把数值0肤赋值给数组中的元素呢?怎么办?
应该不算删除数组元素,只是把要删除的元素赋值为0值了
if (b == a[i]){//要删除的数据
a[i] = r;
}
输出显示是,输出了所有不需要删除的元素,这样从输出显示来看貌似删除数据,但内存中数据仍存在,占有内存空间,只不过此时值被修改为0。
对数组,或者顺序空间元素删除,一般需要数据搬移,需要把后面的数据往前搬移,覆盖删除的空间,这样使内存空间紧凑,不至于零散碎片化。正是由于搬移的原因,有时数据存储采用链表结构,而不采用顺序表~