c語(yǔ)言去除重復(fù)數(shù)據(jù)的方法是什么

小億
245
2023-12-12 20:21:56

C語(yǔ)言去除重復(fù)數(shù)據(jù)的方法有多種,以下是其中一種常見(jiàn)的方法:

  1. 遍歷數(shù)組或鏈表,將每個(gè)元素與后面的元素進(jìn)行比較,如果相同則刪除后面的元素。
    • 對(duì)于數(shù)組,可以使用兩個(gè)嵌套的循環(huán)來(lái)實(shí)現(xiàn)。外層循環(huán)控制比較的起始位置,內(nèi)層循環(huán)比較后面的元素并刪除重復(fù)的元素。
    • 對(duì)于鏈表,可以使用兩個(gè)指針來(lái)實(shí)現(xiàn)。一個(gè)指針指向當(dāng)前節(jié)點(diǎn),另一個(gè)指針在當(dāng)前節(jié)點(diǎn)后面搜索重復(fù)元素并刪除。

以下是一個(gè)使用數(shù)組的示例代碼:

#include <stdio.h>

void removeDuplicates(int arr[], int size) {
    int i, j, k;
    
    for (i = 0; i < size; i++) {
        for (j = i + 1; j < size; j++) {
            if (arr[i] == arr[j]) {
                // 刪除重復(fù)元素
                for (k = j; k < size - 1; k++) {
                    arr[k] = arr[k + 1];
                }
                size--;
                j--;  // 因?yàn)閯h除了一個(gè)元素,需要將內(nèi)層循環(huán)的索引回退一位
            }
        }
    }
}

int main() {
    int arr[] = {1, 2, 3, 2, 4, 3, 5};
    int size = sizeof(arr) / sizeof(arr[0]);
    
    removeDuplicates(arr, size);
    
    printf("去除重復(fù)后的數(shù)組:");
    for (int i = 0; i < size; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    
    return 0;
}

以上代碼的輸出結(jié)果為:去除重復(fù)后的數(shù)組:1 2 3 4 5

0