溫馨提示×

c語言去除重復數據的方法是什么

小億
289
2023-12-12 20:21:56
欄目: 編程語言

C語言去除重復數據的方法有多種,以下是其中一種常見的方法:

  1. 遍歷數組或鏈表,將每個元素與后面的元素進行比較,如果相同則刪除后面的元素。
    • 對于數組,可以使用兩個嵌套的循環來實現。外層循環控制比較的起始位置,內層循環比較后面的元素并刪除重復的元素。
    • 對于鏈表,可以使用兩個指針來實現。一個指針指向當前節點,另一個指針在當前節點后面搜索重復元素并刪除。

以下是一個使用數組的示例代碼:

#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]) {
                // 刪除重復元素
                for (k = j; k < size - 1; k++) {
                    arr[k] = arr[k + 1];
                }
                size--;
                j--;  // 因為刪除了一個元素,需要將內層循環的索引回退一位
            }
        }
    }
}

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

以上代碼的輸出結果為:去除重復后的數組:1 2 3 4 5

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女