题目:
找出数组中重复的数字。
在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。
示例 1:
输入: [2, 3, 1, 0, 2, 5, 3]
输出:2 或 3
题解:
方法一:
利用字典Dictionary,遍历数组,在将数字存入字典前,判断字典中是否存在该数字,若存在,便返回该数字即可,不存在存入数组即可。
public class Solution
{
public int FindRepeatNumber(int[] nums)
{
Dictionary<int,int> res = new Dictionary<int,int>();
int index = 0;
int result = -1;
while(index < nums.Length)
{
if(res.ContainsKey(nums[index]))
{
result = nums[index];
break;
}
else
{
res.Add(nums[index],1);
index++;
}
}
return result;
}
}
方法二:
所以将数组排序后,相邻两值比较即可。
public class Solution
{
public int FindRepeatNumber(int[] nums)
{
Array.Sort(nums);
int index = 0;
while(index < nums.Length)
{
if(nums[index] == nums[index+1])
{
break;
}
else
{
index++;
}
}
return nums[index];
}
}