C语言数组中重复的数字分析及方法

来源:爱站网时间:2019-06-26编辑:网友分享
数组中的数字是连续的,但数组中的一个数字重复,要怎么找出这个数呢?爱站技术频道就这个问题简单为大家介绍C语言 数组中重复的数字分析及方法,希望对你学习这方面知识有帮助!

数组中的数字是连续的,但数组中的一个数字重复,要怎么找出这个数呢?爱站技术频道就这个问题简单为大家介绍C语言数组中重复的数字分析及方法,希望对你学习这方面知识有帮助!

C语言 数组中重复的数字解决方法:

题目:在一个长度为n的数组里的所有数字都在0-n-1的 范围内。数组中某些数字是重复的,但是不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是重复的数字2或者3.

解法1:对于数组进行排序,之后对于已经排序的数组进行遍历便可知道数组中重复的数字。

时间复杂度;O(nlogn);

解法2:建立一个大小为O(N)的哈希表,遍历数组中的元素并判断是否存在于哈希表中。若不存在于哈希表中,将这个元素加入哈希表之中并且继续扫描,若这个元素存在于哈希表中,则:找到了数组中重复的一个数字;

时间复杂度:O(N),空间复杂度:O(N);

解法3:对于给定的数组进行重排。对于下标为i的元素:如果a[i] == i,扫描下一个元素;如果不相等将a[i]与a[a[i]]进行比较,若是相等则找到了一个重复的数字,若没有,那么对于数字进行交换,依次进行。

 

int DuplicateInArray(int arr[],int size) 
{ 
  int i=0; 
  while(i<size) 
  { 
    if(arr[i] == i) 
      ++i; 
    else 
    { 
      if(arr[i] != arr[arr[i]]) 
      {swap(arr[i],arr[arr[i]]);} 
      else 
      {return arr[i];} 
    } 
  } 
  return -1; 
} 
以上就是小编收集的C语言数组中重复的数字分析及方法!其实这个行业的发展前景也非常的不错,小编建议对这方面感兴趣的朋友可以抓住机会学习一下哦!

上一篇:boost获取时间并格式化的方法

下一篇:VC使用编译时间作为版本号标识的方法

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载