温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C语言中怎么去除数组中重复的数字

发布时间:2021-07-07 14:30:29 阅读:806 作者:Leah 栏目:大数据
C语言开发者专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

C语言中怎么去除数组中重复的数字,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

题目描述

在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。

示例 :输入:[2, 3, 1, 0, 2, 5, 3]输出:23
   

思路分析

首先想到的是暴力法—两个for循环实现,缺点很明显:用时过多。再进一步可以先排序数组然后一次for循环,容易找出所有的重复元素以及重复的次数,用时依旧较长。

我们考虑如果每个数字都置出现一次,那么此时是最完美的,每一个下标i对应元素numbers[i],也就是说我们对于数组中的每个元素numbers[i]都把它放在自己应该在的位置上numbers[numbers[i]]上, 如果我们发现有两个元素想往同一个位置上放的时候,说明此元素必然重复

即如下的过程:

  • 如果numbers[i] == i, 那么我们认为number[i]这个元素是在自己的位置上的

  • 否则的话,numbers[i]这个元素就应在numbers[numbers[i]]这个位置上, 于是交换numbers[i]和numbers[numbers[i]]。

  • 重复操作1, 直到number[i]== i, 则继续操作下一个位置的元素, 或者numbers[i] == numbers[numbers[i],元素重复。

 

代码实现

//#include <stdlib.h>   //C语言#include<iostream>using namespace std;//2020.05.22int findRepeatNumber(int* nums, int numsSize) {	//此题无须增加对数组为空、元素个数为0、元素越界情况的判断	for (int i = 0; i < numsSize; i++) {		//如果元素位置不对,则交换		while (nums[i] != i) {			//交换前检查是否相等			if (nums[i] == nums[nums[i]])				return nums[i];			int temp = nums[i];			nums[i] = nums[temp];			nums[temp] = temp;		}	}	return -1;}int main(){	int a[] ={2, 3, 1, 0, 2, 5, 3};	findRepeatNumber(a,7);	printf("%d",findRepeatNumber(a,7));	return 0;}
 
C语言中怎么去除数组中重复的数字  
运行结果

关于C语言中怎么去除数组中重复的数字问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

原文链接:https://my.oschina.net/u/4586915/blog/4427802

AI

开发者交流群×