• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C语言 数组中重复的数字分析及方法

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

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c语言输入数字数组,c语言数组,c语言数组定义,c语言数组赋值,c语言数组排序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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

</div>

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C语言 数组中重复的数字分析及方法
  • C语言查找数组里数字重复次数的方法

相关文章

  • 2017-05-28二叉树前序遍历的非递归算法
  • 2017-05-28C语言 数组指针详解及示例代码
  • 2017-05-28详解C语言求两个数的最大公约数及最小公倍数的方法
  • 2017-08-30数组作为函数参数、scanf初始化指针
  • 2017-05-28学习C++编程的必备软件
  • 2017-05-28详解C++中对构造函数和赋值运算符的复制和移动操作
  • 2017-05-28详解C++设计模式编程中责任链模式的应用
  • 2017-05-28《C++ primer plus》读书笔记(一)
  • 2017-05-28详解C++编程中的vector类容器用法
  • 2017-05-28使用C语言求解扑克牌的顺子及n个骰子的点数问题

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C/C++实现八大排序算法汇总
    • Inline Hook(ring3)的简单C++实现方法
    • 使用C语言操作文件的基本函数整理
    • C++流操作之fstream用法介绍
    • 算法详解之分治法具体实现
    • C++ socket实现miniFTP
    • GCC 编译c程序的方法及过程解析
    • c++利用windows函数实现计时示例
    • C++中的操作符重载详细解析
    • C语言 冒泡排序算法详解及实例

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有