在C語言中,數組的大小是固定的,無法直接刪除數組。但可以通過動態內存分配的方式來模擬刪除數組。具體步驟如下:
示例代碼如下:
#include <stdio.h>
#include <stdlib.h>
int main() {
int *arr = (int*)malloc(5 * sizeof(int));
// 初始化數組
for (int i = 0; i < 5; i++) {
arr[i] = i;
}
// 刪除第3個元素(索引為2)
int newSize = 4;
int *newArr = (int*)malloc(newSize * sizeof(int));
for (int i = 0; i < newSize; i++) {
if (i < 2) {
newArr[i] = arr[i];
} else {
newArr[i] = arr[i+1];
}
}
free(arr); // 釋放原數組的內存空間
arr = newArr; // 將新數組賦值給原數組指針變量
// 打印刪除元素后的數組
for (int i = 0; i < newSize; i++) {
printf("%d ", arr[i]);
}
free(arr); // 釋放新數組的內存空間
return 0;
}
需要注意的是,在刪除數組時,需要手動管理內存分配和釋放,確保不會造成內存泄漏。