33.【C语言】删除数组中的重复元素(Demo)

article/2025/10/3 2:09:15

算法思想

定义4个变量i、j、k,变量i用于控制外层循环的趟数,外层循环每执行一趟,数组arr的有效长度就缩小,大小为k值。在有效长度为k的范围内arr[i]是没有重复元素的。内层循环j和k每次的初值都是i+1,即每次从arr[i]的下一个元素开始。变量j在内层循环中从i+1开始到len-1逐个扫描,扫描到的元素值arr[j]和当前arr[i]不相等,arr[j]就替换arr[k],然后下标j和下标k均向后移。否则下标j不断向后移,下标k保持不动,直到出现arr[j]和arr[i]不相等再继续重复操作。内层循环执行完后,此时k的值就是当前有效数组长度减去与arr[i]相同元素值的个数。并且可以发现下标k往前的元素(不包含此时的arr[k])没有出现和arr[i]值相同的元素,此时的k值作为下一次外层循环和内层循环的有效长度大小。
外层循环执行完成后,k就作为删除全部重复元素后新的数组有效长度,还需要对下标arr[k-1]以后的元素做处理,因为这部分数组元素空间大小是额外所有重复元素的个数。

模拟过程

如下是i=0时一趟处理的结果:
在这里插入图片描述
删除了所有重复元素后,数组会变成如下状态:
在这里插入图片描述
但实际有效长度只有前面元素值不为65535的这一部分,长度为6,所以对打印做下处理,只打印前面长度为6的那一部分。

案例运行效果

在这里插入图片描述

完整代码如下

#include <stdio.h>
#include <stdlib.h>
void remove_repeatednum(int* arr, int len)
{int i, j, k,m=len-1;		//m用于临时存放初始时的数组长度for (i = 0; i < len; i++){for (j = i + 1, k = i + 1; j < len; j++){if (arr[j] != arr[i])arr[k++] = arr[j];} len = k;		//此时len的值为减去数组中与arr[i]重复的元素个数}		//整个循环结束后k的值为去除全部重复值后的数组长度while (m >= k)		//0~k-1为有效部分,将下标范围k到m之间的元素值全用65535代替(假想成这部分空间被释放),在打印的时候,如果元素为该值,则不打印{arr[m] = 65535;m--;}
}
int arr_print(int *arr, int len)
{for (int i = 0; i < len; i++){if (arr[i] == 65535)break;printf("%d ", arr[i]);}printf("\n");
}
int main(void)
{int arr[] = { 1,1,1,2,2,1,3,6,1,4,2,3,5,4,6,1 };int len = sizeof(arr) / sizeof(arr[0]);printf("处理前:");arr_print(arr, len);remove_repeatednum(arr, len);printf("处理后:");arr_print(arr, len);system("pause");return 0;
}

http://chatgpt.dhexx.cn/article/qAgorB9T.shtml

相关文章

LeetCode移除元素(C语言)

给定一个排序数组&#xff0c;你需要在原地删除重复出现的元素&#xff0c;使得每个元素只出现一次&#xff0c;返回移除后数组的新长度。 不要使用额外的数组空间&#xff0c;你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。 示例 1: 给定数组 nums [1,1,2…

C语言删除数组中的重复元素(详细分析版)

&#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f389;推荐up主专题文章 C语言100道经典编程题【详细分析版】 &#x1f4cc;QQ&#xff1a;3052645092 不明白或有问题可以一起讨论哦 &#x1f36d;作者水平很有限&#xff0c;如果发现…

删除多个元素(C语言实现)

删除多个元素 描述格式样例题解及详细注释 描述 从长度为n的整数序列中删除指定位序的m个元素&#xff0c;按照原顺序输出剩余的元素。其中&#xff0c;1≤m≤n≤1000&#xff0c;原整数序列为a&#xff1b;要删除的元素位序按照严格单调递增的方式存储在序列b中&#xff0c;其…

删除数组中重复的元素 C语言

题目介绍&#xff1a; 逻辑实现&#xff1a; 用两个下标 第一个下标src为第二个元素 第二个下标dst为第一个元素 而后 当srcsrc-1时&#xff0c;src&#xff0c;指向下一个元素 &#xff0c;dst不动&#xff0c;如果不等于时候 把src-1的值赋值给dst 尔后两者 注意&#xff1…

详细讲解:C语言删除数组中的某一值的所有元素

具体要求是这样的&#xff0c;通过键盘向程序输入数组中需要删除的数字&#xff0c;程序接到输入后删除数组中所有需要删除的数字。例如&#xff1a; 数组 a[10]{1,2,4,6,4,8,6,2,6,7} 删除数字 :6 输出结果&#xff1a;1 2 4 4 8 2 7想要实现这个功能&#xff0c;其基本思想…

删除数组中重复元素(C语言)

编写函数&#xff0c;删除数组中所有的重复元素&#xff0c;使数组变成一个集合&#xff0c;函数返回集合中元素的个数。 书上习题 #include<stdio.h> int set(int a[],int n) {int i,j,k;for(i0;i<n;i)//每次以a[i]为比较标准{ji1;ki1;while(j<9){if(a[j]a[i]){j…

C语言实现删除元素

给定一组数组&#xff0c;输入一个下标&#xff0c;删除该下标元素并将删除后的数组打印出来。 解题思路&#xff0c;我们主要解决的是删除问题&#xff0c;可以给定一个变量进行循环&#xff0c;让此变量从要删除的下表开始&#xff0c;让被删除的下标的后一个元素赋值给前一个…

STM32工作笔记0021---4G通信模块CAT1和CAT4的区别

技术交流QQ群【JAVA,C,Python,.NET,BigData,AI】&#xff1a;170933152 同是4G模块&#xff0c;CAT1与 CAT4模块的区别有哪些 二 、CAT 与CAT4应用场景对比 CAT1的应用场景&#xff1a;穿戴式设备、智能家电、工业传感器、水文水利的检测、港口物流跟踪。共享支付类。对于宽带…

catboost介绍

一、Catboost简介 全称&#xff1a;Gradient Boosting(梯度提升) Categorical Features(类别型特征)作者&#xff1a;俄罗斯的搜索巨头Yandex官方地址论文链接 | 项目地址 文档地址视频 二、Catboost的特点 一般来说&#xff0c;Gradient Boosting(GB)方法适用于异质化数据。…

nb模块不能接收公网消息_nb模块不能接收公网消息_4G模块Cat1与Cat4的区别究竟在哪里呢?它又为何吸引众多Cat4用户的眼光呢?......

Cat1突然火了&#xff0c;众多行业大佬为其背书。 Cat1凭借其低成本、低功耗等优势与NB-IoT一同扛起了中低速率物联网市场大旗。 与此同时&#xff0c;Cat1也引来众多Cat4用户关注。 那Cat1与Cat4的区别究竟在哪里呢?它又为何吸引众多Cat4用户的眼光呢&#xff1f; 成本优势 1…

【内网学习笔记】20、Hashcat 的使用

1、介绍 Hashcat 是一款用于破解密码的工具&#xff0c;据说是世界上最快最高级的密码破解工具&#xff0c;支持 LM 哈希、MD5、SHA 等系列的密码破解&#xff0c;同时也支持 Linux、Mac、Windows 平台。 工具地址&#xff1a;https://hashcat.net 项目地址&#xff1a;http…

Cat.1和Cat.4的区别

Cat.1 Cat.4 NB-LOT 1.比较2.Cat.1和Cat.4 介绍 1.比较 2.Cat.1和Cat.4 介绍 要区别Cat.1和Cat.4&#xff0c;首先我们要知道Cat是什么。Cat 是 Category 的缩写&#xff0c;中文意思是“类别&#xff0c;种类”。Cat 后面的数字即代表不同的种类&#xff0c;3GPP 将不同种类的…

CAT1 与CAT4 区别与应用

要区别Cat.1和Cat.4&#xff0c;首先我们要知道Cat是什么。Cat 是 Category 的缩写&#xff0c;中文意思是“类别&#xff0c;种类”。Cat 后面的数字即代表不同的种类&#xff0c;3GPP 将不同种类的网络用 “Cat.X” 格式命名。根据 3GPP Release 定义&#xff0c;Cat.X 是用来…

生活网络常识—CAT1与CAT4的区别

大家好&#xff0c;今天给大家讲讲CAT1与CAT4的区别&#xff1b; 给出一张图片让大家生动地看到它们之前的差距与不同&#xff1b; 什么是Cat1与Cat4&#xff1f; 通俗来说我们可以理解为4G网络&#xff08;LTE&#xff09;的种类&#xff0c;分别代表UE的接入能力等级&#…

CAT1和CAT4的区别

现今&#xff0c;CAT1的发展势头一直很迅猛&#xff0c;那为什么CAT4不能替代CAT1的地位呢&#xff1f;&#xff0c;我们来看下面几点&#xff1a; 成本 1. 网络建设方面&#xff0c;Cat1可以无缝接入现有LTE网络当中&#xff0c;无需针对基站进行软硬件升级&#xff0c;网络…

Cat.1、Cat.4、4G之间的区别

什么是Cat.1&#xff1f; Cat.1的全称是LTEUE-Category1&#xff0c;其中UE指的是用户设备&#xff0c;它是LTE网络下用户终端设备的无线性能的分类。根据3GPP的定义&#xff0c;UE类别以1-15分为15个等级。Cat.1&#xff0c;可以称为“低配版”的 4G 终端&#xff0c;上行峰值…

Cat.1和Cat4的应用场景有什么区别

Cat.1是4G通信LTE网络下用户终端类别的一个标准。随着2G网络的承载能力进一步减弱&#xff0c;在新部署的物联网连接中NB-IoT、4G会逐步替代2G模组。相比NB-IoT&#xff0c;Cat.1在网络覆盖、速度和延时上均有优势;相比传统的LTE Cat.4模组则拥有低成本和低功耗优势。 Cat.1与C…

4G通信模块CAT1和CAT4的区别

简介 LTE CAT全名LTEUE-Category&#xff0c;拆开来解释:LTE指的是4GLTE网络、UE是指用户设备、Category翻译为等级。通顺解释就是用户设备能够支持的4GLTE网络传输速率的等级&#xff0c;也可以说成是4G网络速度的一个技术标准。所以LTE CAT1/CAT4就是指用户设备LTE网络接入能…

Python软件编程等级考试一级——20220618

Python软件编程等级考试一级——20220618 理论单选题判断题 实操第一题计算长方形的面积 画图题 Python软件编程等级考试一级——20220618——真题解析 理论 单选题 1、在Python编辑器中写好程序代码后&#xff0c;在Run菜单中&#xff0c;下列哪个命令可以用来执行程序&…

全国青少年编程等级考试python一级真题2021年3月(含题库答题软件账号)

对青少年编程等级考试Python真题答题考试系统关注的请点击 https://blog.csdn.net/zhengzyx2040/article/details/119329247 青少年软件编程&#xff08;Python&#xff09;等级考试试卷&#xff08;一级&#xff09; 分数&#xff1a;100 题数&#xff1a;37 一、单选题(…