c語言數(shù)組怎么去掉重復(fù)元素

小億
133
2024-01-13 14:54:35
欄目: 編程語言

要去掉C語言數(shù)組中的重復(fù)元素,可以使用以下步驟:

  1. 遍歷數(shù)組,比較當(dāng)前元素與之前的元素是否相同。
  2. 如果相同,則將當(dāng)前元素之后的所有元素往前移動(dòng)一位,數(shù)組長(zhǎng)度減一。
  3. 如果不相同,則繼續(xù)遍歷下一個(gè)元素。
  4. 重復(fù)上述步驟,直到遍歷完整個(gè)數(shù)組。

以下是一個(gè)示例代碼:

#include<stdio.h>

int removeDuplicates(int arr[], int n) {
    if (n == 0 || n == 1) // 如果數(shù)組為空或只有一個(gè)元素,直接返回
        return n;

    int temp[n]; // 創(chuàng)建一個(gè)臨時(shí)數(shù)組,用來存儲(chǔ)去重后的元素
    int j = 0; // 臨時(shí)數(shù)組的下標(biāo)

    for (int i = 0; i < n-1; i++) {
        if (arr[i] != arr[i+1]) { // 如果當(dāng)前元素與下一個(gè)元素不相同
            temp[j++] = arr[i]; // 將當(dāng)前元素存入臨時(shí)數(shù)組
        }
    }

    temp[j++] = arr[n-1]; // 將最后一個(gè)元素存入臨時(shí)數(shù)組

    for (int i = 0; i < j; i++) {
        arr[i] = temp[i]; // 將臨時(shí)數(shù)組的元素復(fù)制回原數(shù)組
    }

    return j; // 返回去重后的數(shù)組長(zhǎng)度
}

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

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

    n = removeDuplicates(arr, n);

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

    return 0;
}

輸出結(jié)果:

原始數(shù)組:1 2 2 3 4 4 5 
去重后的數(shù)組:1 2 3 4 5 

0