溫馨提示×

C語言集合怎樣實現(xiàn)去重

小樊
88
2024-07-17 02:29:47
欄目: 編程語言

在C語言中,可以通過以下步驟實現(xiàn)集合去重:

  1. 首先,創(chuàng)建一個新的數(shù)組或鏈表用來存儲去重后的元素。

  2. 遍歷原始數(shù)組或鏈表中的元素,依次將元素插入到新數(shù)組或鏈表中,但在插入之前需要檢查該元素是否已經(jīng)存在于新數(shù)組或鏈表中。

  3. 如果該元素已經(jīng)存在于新數(shù)組或鏈表中,則跳過該元素;如果該元素不存在于新數(shù)組或鏈表中,則將其插入到新數(shù)組或鏈表中。

  4. 最終,新數(shù)組或鏈表中存儲的就是去重后的元素。

下面是一個簡單的示例代碼,演示如何在C語言中實現(xiàn)去重:

#include <stdio.h>

void removeDuplicates(int arr[], int n) {
    int unique[n];
    int size = 0;

    for (int i = 0; i < n; i++) {
        int j;
        for (j = 0; j < size; j++) {
            if (arr[i] == unique[j]) {
                break;
            }
        }
        if (j == size) {
            unique[size++] = arr[i];
        }
    }

    printf("Array with duplicates removed: ");
    for (int i = 0; i < size; i++) {
        printf("%d ", unique[i]);
    }
    printf("\n");
}

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

    removeDuplicates(arr, n);

    return 0;
}

在上面的示例中,removeDuplicates函數(shù)實現(xiàn)了去重功能,它創(chuàng)建了一個新的數(shù)組unique來存儲去重后的元素。通過遍歷原始數(shù)組arr,將不重復的元素插入到unique數(shù)組中,最后輸出去重后的元素。

0