C言語の配列で重複する要素を取り除く方法は何ですか?

C言語の配列から重複する要素を取り除くには、以下の手順を使用することができます:

  1. 配列を繰り返し、現在の要素と以前の要素を比較する。
  2. もし同じ要素があれば、その要素以降の全ての要素を一つ前に移動し、配列の長さを1減らす。
  3. もし違うなら、次の要素を引き続き探索する。
  4. 配列全体を横断するまで、上記の手順を繰り返します。

以下はサンプルコードです。

#include<stdio.h>

int removeDuplicates(int arr[], int n) {
    if (n == 0 || n == 1) // 如果数组为空或只有一个元素,直接返回
        return n;

    int temp[n]; // 创建一个临时数组,用来存储去重后的元素
    int j = 0; // 临时数组的下标

    for (int i = 0; i < n-1; i++) {
        if (arr[i] != arr[i+1]) { // 如果当前元素与下一个元素不相同
            temp[j++] = arr[i]; // 将当前元素存入临时数组
        }
    }

    temp[j++] = arr[n-1]; // 将最后一个元素存入临时数组

    for (int i = 0; i < j; i++) {
        arr[i] = temp[i]; // 将临时数组的元素复制回原数组
    }

    return j; // 返回去重后的数组长度
}

int main() {
    int arr[] = {1, 2, 2, 3, 4, 4, 5};
    int n = sizeof(arr) / sizeof(arr[0]);

    printf("原始数组:");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }

    n = removeDuplicates(arr, n);

    printf("\n去重后的数组:");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }

    return 0;
}

結果表示:

原始数组:1 2 2 3 4 4 5 
去重后的数组:1 2 3 4 5 
bannerAds