We read every piece of feedback, and take your input very seriously.
To see all available qualifiers, see our documentation.
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Given an array of integers, 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once.
Find all the elements that appear twice in this array.
Could you do it without extra space and in O(n) runtime?
Example:
Input: [4,3,2,7,8,2,3,1] Output: [2,3]
一个数组中的元素是在1~n的范围内,并且有的出现两次,有的出现一次,要求找到出现两次的元素,并且时间复杂度在O(n),没有额外空间。
这道题的难点在于如何用有限的条件完成不用额外空间的算法。不用多余的空间,我们每次遍历对每个元素只能设置一个变量,显然是不足以完成题目条件的。那么,我们要注意到题目还有个限制条件:数组元素是在1~n的范围内,而且也要利用数组空间。
解法:将数组元素当作一个索引,因为数组元素的范围限制,那么按照该元素索引的数组元素做一个标志,如果是正数,代表该索引第一次使用,设置成相反数,如果是负数,说明当前索引已经被使用过,则加入到结果集合中。
class Solution { public List<Integer> findDuplicates(int[] nums) { ArrayList<Integer> list = new ArrayList<>(); int i; for (i = 0; i < nums.length; ++i) { if (nums[Math.abs(nums[i]) - 1] < 0) { list.add(Math.abs(nums[i])); }else { nums[Math.abs(nums[i]) - 1] = -nums[Math.abs(nums[i]) - 1]; } } return list; } }
关键:
参考资料:
The text was updated successfully, but these errors were encountered:
No branches or pull requests
Given an array of integers, 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once.
Find all the elements that appear twice in this array.
Could you do it without extra space and in O(n) runtime?
Example:
一个数组中的元素是在1~n的范围内,并且有的出现两次,有的出现一次,要求找到出现两次的元素,并且时间复杂度在O(n),没有额外空间。
这道题的难点在于如何用有限的条件完成不用额外空间的算法。不用多余的空间,我们每次遍历对每个元素只能设置一个变量,显然是不足以完成题目条件的。那么,我们要注意到题目还有个限制条件:数组元素是在1~n的范围内,而且也要利用数组空间。
解法:将数组元素当作一个索引,因为数组元素的范围限制,那么按照该元素索引的数组元素做一个标志,如果是正数,代表该索引第一次使用,设置成相反数,如果是负数,说明当前索引已经被使用过,则加入到结果集合中。
关键:
参考资料:
The text was updated successfully, but these errors were encountered: