剑指 offer 数组中重复的数字

快乐的工程师 · · 1746 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

算法名称:数组中重复的数字

题目内容:

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

解题思路:

(1) 一个简单的思路是先将数组排序,然后从头开始寻找重复数字。排序的时间复杂度为O(nlogn);

(2) 利用hash表存储元素,若表中存在元素则找到重复数字。Hash查询时间仅用O(1),算法时间复杂度为O(n),但是需要一个哈希表,空间复杂度为O(n);

(3) 利用元素数字都在0到n-1的范围内的特点,若不存在重复数字,则排序后的数字就在与其相同的索引值的位置,即数字i在第i个位置。遍历的过程中寻找位置和元素不相同的值,并进行交换排序。时间复杂度O(n),空间复杂度O(1)。

实例代码:

  • Java版
class Solution {

 public int findRepeatNumber(int[] nums) {

 if (nums.length == 0) {

 return 0;

 }

 Arrays.sort(nums);

 for (int i = 0; i \< nums.length - 1; i++) {

 if (nums[i] == nums[i + 1]) {

 return nums[i];

 }

 }

 return 0;

 }

}
  • Golang版
func findRepeatNumber(nums []int) int {

 if len(nums) == 0 {

 return 0

 }

 sort.Ints(nums)

 for i := 0; i \< len(nums)-1; i++ {

 if nums[i] == nums[i+1] {

 return nums[i]

 }

 }

 return 0

}

本题考点:

  • 考察面试者对一维数组的理解与编程能力。一维数组在内存中占据连续的空间,因此我们可以根据下标定位对应的元素。

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:快乐的工程师

查看原文:剑指 offer 数组中重复的数字

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1746 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传