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。
对数组,或者顺序空间元素删除,一般需要数据搬移,需要把后面的数据往前搬移,覆盖删除的空间,这样使内存空间紧凑,不至于零散碎片化。正是由于搬移的原因,有时数据存储采用链表结构,而不采用顺序表~
不知道你什么意思?数组中所有的元素都赋值为0还是别的?
可以设置r=65535,代表元素值无效。如果还是觉得不是很好,只能是设计一个数据类型
typedef struct data{
int len=0;//数组长度
int a[5];
}
不用定义 r ,直接赋值 a[i] = 0 即可。
这样的赋值方法,已经将数组中的元素赋值为零了。
那就在循环了面加 if(i==3){
a【i】 = 0;}
这不需要定义r吧,直接赋值0,但是如果遇到数据位0的呢,该怎么办吧,直接将后排的覆盖之前删除的那一位,也是可行的
不明白你想怎么删除!!!