c语言数组怎么去掉重复元素

   2025-02-05 5930
核心提示:要去掉C语言数组中的重复元素,可以使用以下步骤:遍历数组,比较当前元素与之前的元素是否相同。如果相同,则将当前元素之后的

要去掉C语言数组中的重复元素,可以使用以下步骤:

遍历数组,比较当前元素与之前的元素是否相同。如果相同,则将当前元素之后的所有元素往前移动一位,数组长度减一。如果不相同,则继续遍历下一个元素。重复上述步骤,直到遍历完整个数组。

以下是一个示例代码:

#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 

 
 
更多>同类维修知识
推荐图文
推荐维修知识
点击排行
网站首页  |  关于我们  |  联系方式  |  用户协议  |  隐私政策  |  网站留言