442. 数组中重复的数据
442. 数组中重复的数据
给定一个整数数组 a,其中1 ≤ a[i] ≤ n (n为数组长度), 其中有些元素出现两次而其他元素出现一次。
找到所有出现两次的元素。
你可以不用到任何额外空间并在O(n)时间复杂度内解决这个问题吗?
示例:
输入:
[4,3,2,7,8,2,3,1]
输出:
[2,3]
代码如下:
class Solution {
/**
* @param Integer[] $nums
* @return Integer[]
*/
function findDuplicates($nums) {
$result = [];
$newArr = array_count_values($nums);
foreach ($newArr as $key => $item) {
if ($item == 2) $result[] = $key;
}
return $result;
}
}