题目
给定一个长度为 nn 的整数数组 nums
,数组中所有的数字都在 0∼n−10∼n−1 的范围内。
数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。
请找出数组中任意一个重复的数字。
注意:如果某些数字不在 0∼n−10∼n−1 的范围内,或数组中不包含重复数字,则返回 -1;
数据范围
0≤n≤1000
样例
给定 nums = [2, 3, 5, 4, 3, 2, 6, 7]。
返回 2 或 3。
思路:
先排序,再进行检索找出重复数字
TIP:
只要有大于数组长度的数字就要返回-1,所以不能直接找到重复数字就return,而要优先检验数组中没有大于数组长度的数字
应该先验证有没有大于数组长度的数字,再看是否有重复数字
原错误:for(i=0;i<numsSize;i++)
{
if(nums[i]>numsSize-1 || nums[i]<0) return -1;
if(nums[i]==nums[i+1]) return nums[i];
}
代码
int duplicateInArray(int *nums, int numsSize){
int i,j,k,t,temp=-1;
for(i=0;i<numsSize-1;i++) //排序
{
k=i;
for(j=i+1;j<numsSize;j++)
if(nums[k]>nums[j])
k=j;
if(k!=i)
{
t=nums[i];nums[i]=nums[k];nums[k]=t;
}
}
for(i=0;i<numsSize;i++)
{
if(nums[i]>numsSize-1 || nums[i]<0) return -1;
if(nums[i]==nums[i+1]) temp=nums[i];
}
return temp;
}
ps:这样的方法比较笨,时间复杂度也较高,还有完善提高的空间