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;}}}
}

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

外层循环

for (i = 0; i < *n; ++i) {

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

内层循环

for (j = i + 1; j < *n;) {

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

元素比较

if (arr[i] == arr[j]) {

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

重复元素处理

for (k = j; k < *n - 1; ++k) {arr[k] = arr[k + 1];
}

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

数组大小减小

--(*n);

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

内层循环控制

++j;

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

使用示例

#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;
}
1 2 3 4 5

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

总结

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/240777.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言易错知识点九(指针(part three))

❀❀❀ 文章由不准备秃的大伟原创 ❀❀❀ ♪♪♪ 若有转载&#xff0c;请联系博主哦~ ♪♪♪ ❤❤❤ 致力学好编程的宝藏博主&#xff0c;代码兴国&#xff01;❤❤❤ 许久不见&#xff0c;甚是想念&#xff0c;本大忙人已经很久没有更新博客了&#xff0c;我想大概我的粉丝们早…

Linux的/proc/self/学习

文章目录 /proc目录/proc/self的使用 在做SSTI模板注入的CTF题中&#xff0c;发现有师傅提到可以用/proc/self这个目录获取flag&#xff0c;所以也来学习一波主要参考. (我才知道&#x1f601;&#x1f601;&#x1f601;)可以通过/proc/$pid/来获取指定进程的信息&#xff0c…

Kioptrix-3

靶场下载地址 https://download.vulnhub.com/kioptrix/KVM3.rar 信息收集 # Nmap 7.94 scan initiated Thu Dec 21 21:52:25 2023 as: nmap -sn -oN live.nmap 192.168.1.0/24 Nmap scan report for 192.168.1.1 (192.168.1.1) Host is up (0.00048s latency). MAC Address:…

[了解]DOS命令相对路径绝对路径

DOS: 磁盘操作系统 操作原理&#xff1a;在cmd控制台输入指令后--->交给DOS系统(接收\解析\执行)--->操作windows系统文件夹目录 dos指令: md d:\\temp md test100 test200 在d盘创建了一个文件夹目录叫temp。 在当前文件夹目录下创建了两个目录test100 test200。 r…

AI绘画中VAE压缩图像

介绍 在Stable Diffusion中,所有的去噪和加噪过程并非在图像空间直接进行,而是通过VAE模块将图像编码到一个低维空间。 这个低维空间的“分辨率”低于原始图像空间,有利于快速地完成加噪和去噪过程。 最后再将编码空间中的噪声表示解码恢复为图像空间,完成去噪或加噪操作。 …

【Element】el-table 使用 el-table-infinite-scroll 插件实现滚动加载

虽然 el 官方提供了 Infinite Scroll 无限滚动 组件 但是却不支持 el-table 组件&#xff0c;这就很难受了&#xff0c;还好已经有大佬写好了插件&#xff0c;并且支持 element-plus/infinite-scroll 组件的所有选项。 el-table-infinite-scroll el-table-infinite-scroll 看…

【数据结构入门精讲 | 第十二篇】考研408、公司面试树专项练习(一)

在上一篇文章中我们介绍了树的知识点&#xff0c;在这一篇中我们将进行树的专项练习。 目录 判断题选择题填空题二叉树的宽度R6-1 是否二叉搜索树 方法介绍&#xff1a; 已知中序及后序&#xff0c;求前序 如后序为DABEC,中序为DEBAC&#xff0c;求前序 则后序倒着写&#xff…

北京Modbus转Profinet网关的作用

背景&#xff1a;随着工业自动化的快速发展&#xff0c;各种仪器设备迅速崛起&#xff0c;但是在仪器出厂前需要很多的零部件来构建出需要的设备及功能&#xff0c;由于自动化设备的零部件不是统一生产商供应的&#xff0c;这样很容易出现某个零部件的通讯协议不匹配&#xff0…

搜索二叉树(超详解)

文章目录 前言查找搜索二叉树的结构insertfinderase递归版本Findinserterase 二叉树的拷贝问题搜索二叉树的应用Key模型Key/Value的模型 前言 普通二叉树其实意义不大&#xff0c; 如果用二叉树存储数据的话&#xff0c;还不如顺序表&#xff0c;链表这些。 搜索二叉树它的意义…

7.5组合总和②(LC40-M)

算法&#xff1a; 相比于上一题&#xff0c;数组candidates有重复元素&#xff0c;而要求不能有重复的组合&#xff0c;所以相对于39.组合总和 (opens new window)难度提升了不少。 如何去重&#xff1f; 先把candidates排序&#xff0c;让重复的元素都在一起 单层递归时&a…

TCP的poll多路复用实现群聊

服务器 #include <myhead.h> #define SERIP "192.168.125.99" #define SERPORT 9999 int main(int argc, const char *argv[]) {int sfd-1;if((sfdsocket(AF_INET,SOCK_STREAM,0))-1){perror("socket error");return -1;}printf("sfd%d\n"…

MyBatis的关联查询!!!(一对一、一对多、多对多)

准备工作&#xff1a; 1.创建Maven工程&#xff0c;还没有配置Maven的和还不会的去看这里啦&#xff1a;maven的下载安装与配置环境变量&#xff01;&#xff01;&#xff01;&#xff08;全网最详细&#xff09;-CSDN博客 Account.java : (pojo类) &#xff08;这里我…

torch中关于张量是否是叶子结点,张量梯度是否会被计算,张量梯度是否会被保存的感悟

先上结论&#xff1a; 1、叶子结点定义: &#xff08;1&#xff09;不依赖其它任何结点的张量 &#xff08;2&#xff09;依赖其它张量&#xff0c;但其依赖的所有张量的require_gradFalse # 判断方法&#xff1a;查看is_leaf属性 2、张量梯度是否会被计算: require_…

SpringMVC之文件的下载

系列文章目录 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 SpringMVC之文件的下载 提示&#xff1a;写完文章后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 系列文章目录前言一、文件下载实现…

认识Linux背景

1.发展史 Linux从哪里来&#xff1f;它是怎么发展的&#xff1f;在这里简要介绍Linux的发展史 要说Linux&#xff0c;还得从UNIX说起 UNIX发展的历史 1968年&#xff0c;一些来自通用电器公司、贝尔实验室和麻省理工学院的研究人员开发了一个名叫Multics的特殊操作系统。Mu…

分布式锁常见问题及其解决方案

一、为什么要使用分布式锁&#xff1f; 因为在集群下&#xff0c;相当于多个JVM&#xff0c;就相当于多个锁&#xff0c;集群之间锁是没有关联的&#xff0c;会照成锁失效从而导致线程安全问题 分布式锁可以分别通过MySQL、Redis、Zookeeper来进行实现 二、redis分布式锁的实…

华为发布全闪备份一体机旗舰新品,并宣布备份软件开源

[中国&#xff0c;上海&#xff0c;2023年12月20日]在20日举行的OceanProtect数据保护新品发布会上&#xff0c;华为发布全闪备份一体机旗舰新品&#xff0c;并宣布备份软件开源&#xff0c;以应对智慧金融、自动驾驶等场景对数据备份效率及数据安全方面的新诉求&#xff0c;为…

工业信息采集平台的五大核心优势

关键字&#xff1a;工业信息采集平台,蓝鹏数据采集系统,蓝鹏测控系统, 生产管控系统, 生产数据处理平台,MES系统数据采集, 蓝鹏数据采集平台通过实现和构成其他工业数据信息平台的一级设备进行通讯&#xff0c;从而完成平台之间的无缝对接。这里我们采用的最多的方式是和PLC进行…

神经网络:深度学习基础

1.反向传播算法&#xff08;BP&#xff09;的概念及简单推导 反向传播&#xff08;Backpropagation&#xff0c;BP&#xff09;算法是一种与最优化方法&#xff08;如梯度下降法&#xff09;结合使用的&#xff0c;用来训练人工神经网络的常见算法。BP算法对网络中所有权重计算…

力扣labuladong——一刷day77

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、力扣207. 课程表 前言 图这种数据结构有一些比较特殊的算法&#xff0c;比如二分图判断&#xff0c;有环图无环图的判断&#xff0c;拓扑排序&#xff0c;以…