1、只要将删除后的数据元素像前移动一位即可。
2、例程:
#include
// 删除长度为len的数组dat中索引为idx的元素。
void remove(int *dat, int *len, int idx)
{
(*len)--;
if (idx < 0 || idx >= *len)
return;
for (int i = idx; i < *len; i++)
dat[i] = dat[i+1];
}
void output(int *dat, int len)
{
for (int i = 0; i < len; i++)
printf("%d ", dat[i]);
printf("\n");
}
int main()
{
int a[10]= {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}, len = 10;
remove(a, &len, 5);
output(a, len);
remove(a, &len, 2);
output(a, len);
return 0;
}
静态数组的存储空间是固定的,不能改变,如果你删除了元素,只要把后面的元素往前移就行了,剩余的空间可以不管了。
动态数组的话(new分配)其实也不能改变数组大小,只是把指针指向了另外分配的空间
静态定义的数组是不能改变长度的
除非是动态new动义
动态数组delete 掉那个空间就可以删除那个元素了
希望对你有用
#include
void main()
{
char a[5]="cjdh";
int i=0;
cout<cout<<"删除‘j’:\n";
for(i=1;i<5;i++)
a[i]=a[i+1];
cout<
}
这样可以吗?
数组中的元素前移或后移覆盖。。要跟踪数组长度