题目描述:

给定一个包含 n + 1 个整数的数组 nums ,其数字都在 1 到 n 之间包括 1 和 n),可知至少存在一个重复的整数。

假设 nums 只有 一个重复的整数 ,找出 这个重复的数 。

你设计的解决方案必须不修改数组 nums 且只用常量级 O(1) 的额外空间。

image.png

解题思路:先对数组进行排序,排序后重复的数必然相邻。

解:

class Solution {

public int findDuplicate(int[] nums) {

int err[] =new int[1];

Arrays.sort(nums);

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

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

err[0]=nums[i];

}

return err[0];

}

}