算法-数组中重复的数字

简介:

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
//原文地址:http://www.cnblogs.com/xiaofeixiang
-( NSInteger )duplicate:( NSMutableArray  *)array{
     for  ( NSInteger  i=0;i<[array count];i++) {
         while  (i!=[array[i] integerValue]) {
             if  ([array[[array[i] integerValue]] isEqualTo:array[i]]) {
                 return  [array[i] integerValue];
             }
             NSInteger   temp=[array[[array[i] integerValue]] integerValue];
             array[[array[i] integerValue]]=array[i];
             array[i]=[ NSNumber  numberWithInteger:temp];
         }
     }
     return  -1;
}

测试代码:

1
2
3
4
NSMutableArray   *dataSource=[[ NSMutableArray  alloc]initWithObjects:@ "2" ,@ "3" ,@ "1" ,@ "4" ,@ "1" nil ];
NSInteger   index=[search duplicate:dataSource];
NSLog (@ "重复的数字:%ld" ,index);
NSLog (@ "技术交流群:%@" ,@ "228407086" );

还存在另外一种解法,比较简单,很绕,有兴趣的可以研究一下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
-( NSInteger )duplicate:( NSMutableArray  *)array{
     for  ( NSInteger  i= 0 ; i<[array count]; i++) {
         NSInteger  index =[array[i] integerValue];
         if  (index >= [array count]) {ki,k   /.m m,l; '' j im9l./
 
             index -= [array count];
         }
         if  ([array[index] integerValue] >= [array count]) {
             return  index;
         }
         array[index]=[ NSNumber  numberWithInteger:[array[index] integerValue] + [array count] ];
     }
     return  - 1 ;
}
本文转自Fly_Elephant博客园博客,原文链接:http://www.cnblogs.com/xiaofeixiang/p/4626697.html,如需转载请自行联系原作者
相关文章
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
167 0
|
10月前
|
存储 监控 算法
关于员工上网监控系统中 PHP 关联数组算法的学术解析
在当代企业管理中,员工上网监控系统是维护信息安全和提升工作效率的关键工具。PHP 中的关联数组凭借其灵活的键值对存储方式,在记录员工网络活动、管理访问规则及分析上网行为等方面发挥重要作用。通过关联数组,系统能高效记录每位员工的上网历史,设定网站访问权限,并统计不同类型的网站访问频率,帮助企业洞察员工上网模式,发现潜在问题并采取相应管理措施,从而保障信息安全和提高工作效率。
190 7
|
算法 测试技术
【算法】二分算法——寻找旋转排序数组中的最小值
【算法】二分算法——寻找旋转排序数组中的最小值
140 0
|
算法
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
208 0
|
11月前
|
存储 人工智能 算法
C 408—《数据结构》算法题基础篇—数组(通俗易懂)
408考研——《数据结构》算法题基础篇之数组。(408算法题的入门)
745 23
|
存储 算法 Go
算法学习:数组 vs 链表
算法学习:数组 vs 链表
454 0
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
275 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
194 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
存储 算法 调度
【数据结构与算法】详解循环队列:基于数组实现高效存储与访问
【数据结构与算法】详解循环队列:基于数组实现高效存储与访问

热门文章

最新文章