array也就是数组,要删除数组中的某一个元素,由于数组的连续性,不可能直接删除掉对应的存储空间,所以唯一的方法就是用数组后续元素覆盖要删除的元素。即从要删除元素下一个元素开始,一直到数组结束,每个元素均向前移动一位。
以下是删除一个数组中某个元素的模板函数:
template
int remove_from_array(T *a, int n, int &l)//从数组a中删除第n个元素。l为数组原始长度,引用传参,所以可以将新的长度带回主调函数。如果成功,函数返回0,否则函数返回-1。
{
if(a == NULL || n<0 || l < 0 || n>=l)return -1;
int i;
for(i = n; i < l-1; i ++)
{
a[i] = a[i+1];//依次用后续一个元素覆盖前一个元素,直到数组尾。
}
l--;
return 0;
}
#include//我用c写的
int main(void)
{
void remove(int* heap, int key, int size);
int a[]={0,2,1,4,3,9,5,7,6,8,1,2,3,8,6,4};
int s;
int k=2;
s=sizeof(a)/sizeof(int);
remove(a,k,s);
return 0;
}
void remove(int* heap, int key, int size)
{
int i,j;
for(i=0;i{
if(key==*(heap+i))
{
j=i;
for(j;j{
*(heap+j)=*(heap+j+1);
}
size--;
}
}
for(i=0;iprintf("%d ",*(heap+i));
printf("\n");
}
for (int i=0;i
if(heap[i]==key){
for (int j=i;j<(size-i);j++){//不是size-i,直接是size
heap[j]=heap[j+1];
}
size--;
}
定义的变量不能被删除,最多只能把其内容清空为 NULL。将数组某个元素删除很简单,比如你有一个数组叫做a,如果你要清空里面第一个成员为 NULL,那么 a[0]=NULL; 就行
for循环,当前位置开始往后,每一位左移。
直接调用标准类方法
ArrayList a = new Arraylist();
.......
a.remove(index);
index是序号