C语言实现对数组去重算法详解

介绍

在编程中,经常会遇到需要对数组进行去重的情况,即去除数组中重复的元素,使得每个元素都是唯一的。本文将详细解释一个用于去重的C语言函数,并逐步解释其中的每一部分。

代码解析

下面是用于去重的C语言函数:

c 复制代码
void removeDuplicates(int arr[], int *n) {
    int i, j, k;

    for (i = 0; i < *n; ++i) {
        for (j = i + 1; j < *n;) {
            if (arr[i] == arr[j]) {
                // 移动数组元素覆盖重复的元素
                for (k = j; k < *n - 1; ++k) {
                    arr[k] = arr[k + 1];
                }
                // 减少数组大小
                --(*n);
            } else {
                ++j;
            }
        }
    }
}

这个函数接受一个整型数组和该数组的大小(通过指针传递),然后修改原始数组,使其不包含重复的元素。接下来,我们将逐步解释这段代码的工作原理。

外层循环

c 复制代码
for (i = 0; i < *n; ++i) {

外层循环从数组的第一个元素开始,遍历到倒数第二个元素。i表示当前正在考虑的元素的索引。

内层循环

c 复制代码
for (j = i + 1; j < *n;) {

内层循环从外层循环的当前元素的下一个元素开始,遍历到数组的最后一个元素。j表示当前正在检查的元素的索引。

元素比较

c 复制代码
if (arr[i] == arr[j]) {

在内层循环中,我们检查当前元素arr[i]是否与后续元素arr[j]相等。

重复元素处理

c 复制代码
for (k = j; k < *n - 1; ++k) {
    arr[k] = arr[k + 1];
}

如果发现重复元素,就将数组中从arr[j]开始的元素逐个向前移动,覆盖掉重复的元素。这样,数组中的重复元素就被覆盖掉了。

数组大小减小

c 复制代码
--(*n);

每当覆盖一个重复元素后,数组的大小就减小1。这是通过修改传递进来的指针所指向的值来实现的。

内层循环控制

c 复制代码
++j;

如果没有发现重复元素,就将内层循环的控制变量j递增,继续比较下一个元素。

使用示例

c 复制代码
#include<stdio.h>
void removeDuplicates(int arr[], int *n) {
    int i, j, k;

    for (i = 0; i < *n; ++i) {
        for (j = i + 1; j < *n;) {
            if (arr[i] == arr[j]) {
                // 移动数组元素覆盖重复的元素
                for (k = j; k < *n - 1; ++k) {
                    arr[k] = arr[k + 1];
                }
                // 减少数组大小
                --(*n);
            } else {
                ++j;
            }
        }
    }
}

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

    // 调用去重函数
    removeDuplicates(all, &n);

    // 打印去重后的数组
    int i;
	for (i = 0; i < n; ++i) {
        printf("%d ", all[i]);
    }

    return 0;
}
bash 复制代码
1 2 3 4 5

通过上述的示例代码,我们可以清晰地看到该去重算法的工作过程。在示例中,原始数组为{1, 2, 2, 3, 4, 4, 5},去重后的结果为{1, 2, 3, 4, 5}

总结

这篇博客详细解释了一个用于数组去重的C语言函数。通过理解该算法,我们可以更好地处理数组中的重复元素,从而得到一个唯一元素构成的数组。这对于数据处理和算法实现都有着重要的意义。

相关推荐
Tisfy2 分钟前
LeetCode 3740.三个相等元素之间的最小距离 I:今日先暴力,“明日“再哈希
算法·leetcode·哈希算法·题解·模拟·遍历·暴力
网域小星球8 分钟前
C语言从0入门(八)|函数基础:封装、调用与参数传递精讲
c语言·开发语言
汀、人工智能17 分钟前
[特殊字符] 第77课:最长递增子序列
数据结构·算法·数据库架构·图论·bfs·最长递增子序列
网域小星球17 分钟前
C语言从0入门(十)|二维数组详解与矩阵实战
c语言·算法·矩阵·二维数组·数组遍历
网域小星球19 分钟前
C 语言从 0 入门(十五)|综合小项目:菜单交互与简易功能实现
c语言·开发语言·交互
澈20723 分钟前
堆排序:高效构建大顶堆实战
数据结构·算法·排序算法
网域小星球29 分钟前
C 语言从 0 入门(十六)|动态内存管理:malloc /free/calloc /realloc 精讲
c语言·开发语言·free·malloc·动态内存
chh56342 分钟前
C++--内存管理
java·c语言·c++·windows·学习·面试
我真不是小鱼1 小时前
cpp刷题打卡记录27——无重复字符的最长子串 & 找到字符串中所有字母的异位词
数据结构·c++·算法·leetcode
XuecWu31 小时前
原生多模态颠覆Scaling Law?解读语言“参数需求型”与视觉“数据需求型”核心差异
人工智能·深度学习·算法·计算机视觉·语言模型