- 题目描述:
- 给定一个包含 n + 1 个整数的数组 nums ,其数字都在 1 到 n 之间包括 1 和 n),可知至少存在一个重复的整数。
- 假设 nums 只有 一个重复的整数 ,找出 这个重复的数 。
- 你设计的解决方案必须不修改数组 nums 且只用常量级 O(1) 的额外空间。
- 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];
- }
- }
题目描述:
给定一个包含 n + 1 个整数的数组 nums ,其数字都在 1 到 n 之间包括 1 和 n),可知至少存在一个重复的整数。
假设 nums 只有 一个重复的整数 ,找出 这个重复的数 。
你设计的解决方案必须不修改数组 nums 且只用常量级 O(1) 的额外空间。

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