在 C 語言中,數組的長度是固定的,無法直接刪除元素。但是可以通過將后面的元素向前移動,覆蓋要刪除的元素來實現效果。
以下是一個示例代碼,演示了如何刪除數組中指定位置的元素:
#include <stdio.h>
#define SIZE 5
void deleteElement(int arr[], int *size, int index) {
if (index >= *size) {
printf("Invalid index\n");
return;
}
for (int i = index; i < *size - 1; i++) {
arr[i] = arr[i + 1];
}
(*size)--;
}
int main() {
int arr[SIZE] = {1, 2, 3, 4, 5};
int size = SIZE;
printf("Original Array: ");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
printf("\n");
int index = 2; // 要刪除的元素的索引
deleteElement(arr, &size, index);
printf("Updated Array: ");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
輸出結果:
Original Array: 1 2 3 4 5
Updated Array: 1 2 4 5
在上述示例中,deleteElement
函數接受一個數組、數組的大小(通過指針的方式傳遞)和要刪除的元素的索引。函數首先檢查索引是否有效,然后將索引后面的元素向前移動一位,并將數組的大小減 1。
在 main
函數中,我們定義了一個長度為 5 的數組,并初始化為 {1, 2, 3, 4, 5}。然后調用 deleteElement
函數刪除索引為 2 的元素(即數字 3)。最后打印更新后的數組。
請注意,這種方法只是覆蓋了要刪除的元素,并沒有真正地從內存中刪除它。如果需要動態調整數組長度并刪除元素,可以考慮使用動態內存分配(如 malloc
和 free
函數)來實現。