[Algorithms with Rust] #1 firstDuplicate - CodeSignal
firstDuplicate
Given an array a
that contains only numbers in the range from 1 to a.length
,
find the first duplicate number for which the second occurrence has the minimal index. In other words, if there are more than 1 duplicated numbers, return the number for which the second occurrence has a smaller index than the second occurrence of the other number does. If there are no such elements, return -1.
Example
-
For
a = [2, 1, 3, 5, 3, 2]
, the output should befirstDuplicate(a) = 3
.There are
2
duplicates: numbers2
and3
. The second occurrence of3
has a smaller index than the second occurrence of2
does, so the answer is3
. -
For
a = [2, 2]
, the output should befirstDuplicate(a) = 2
; -
For
a = [2, 4, 3, 5, 1]
, the output should befirstDuplicate(a) = -1
.
Input/Output
-
[execution time limit] 2 seconds (rs)
-
[input] array.integer a
Guaranteed constraints:
1 ≤ a.length ≤ 10**5,
1 ≤ a[i] ≤ a.length.
-
[output] integer
The element in
a
that occurs in the array more than once and has the minimal index for its second occurrence. If there are no such elements, return -1.
Solution
- Using array:
fn firstDuplicate(a: Vec<i32>) -> i32 {
let mut check = Vec::new();
for _ in 0..100001 {
check.push(0);
}
for i in a {
check[i as usize] += 1;
if check[i as usize] >= 2 {
return i;
}
}
return -1;
}
- Using HashMap:
use std::collections::HashMap;
fn firstDuplicate(a: Vec<i32>) -> i32 {
let mut map = HashMap::new();
for &i in &a {
if map.contains_key(&i) {
return i
} else {
map.insert(i, 1);
}
}
return -1;
}