C言語の配列から要素を削除の方法

C言語において、配列は固定長であり、要素の削除は直接行えません。代わりに、要素を移動させて削除動作をシミュレートします。一般的な手法は以下のとおりです。

  1. 削除する要素のインデックス位置を見つける。
  2. indexより後の要素をすべてひとつ前に移動させ、削除した要素の空白を埋める。
  3. 配列の長さを1減算する。

以下に、配列から要素を削除する方法を示すコード例を示します。

#include <stdio.h>

void deleteElement(int arr[], int size, int index) {
    if (index < 0 || index >= size) {
        printf("Invalid index\n");
        return;
    }
    
    // 将index之后的元素向前移动一位
    for (int i = index; i < size - 1; i++) {
        arr[i] = arr[i+1];
    }
    
    // 数组长度减1
    size--;
    
    // 输出删除元素后的数组
    printf("After deletion: ");
    for (int i = 0; i < size; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
}

int main() {
    int arr[] = {1, 2, 3, 4, 5};
    int size = sizeof(arr) / sizeof(arr[0]);
    
    int index;
    printf("Enter the index of element to delete: ");
    scanf("%d", &index);
    
    deleteElement(arr, size, index);
    
    return 0;
}

上記のサンプルコードでは、ユーザーは削除対象の要素のインデックスを入力し、関数deleteElementを呼び出して削除します。関数は削除対象の要素より後ろの要素を 1 つ前へシフトし、削除後の配列を出力します。

bannerAds