-
Notifications
You must be signed in to change notification settings - Fork 95
/
140.py
44 lines (33 loc) · 1.21 KB
/
140.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
"""
Problem:
Given an array of integers in which two elements appear exactly once and all other
elements appear exactly twice, find the two elements that appear only once.
For example, given the array [2, 4, 6, 8, 10, 2, 6, 10], return 4 and 8. The order does
not matter.
Follow-up: Can you do this in linear time and constant space?
"""
from typing import List, Tuple
def get_uniques(arr: List[int]) -> Tuple[int, int]:
xor_result = 0
for val in arr:
xor_result = xor_result ^ val
# using the rightmost set bit as mask to segregate the array of numbers into 2 sets
# performing xor for num1 and num2 based on the set to which they belong to (the 2
# sets are based on whether a number has rightmost_set_bit of the xor result 1 or 0)
rightmost_set_bit = xor_result & ~(xor_result - 1)
num1, num2 = 0, 0
for val in arr:
if val & rightmost_set_bit:
num1 = num1 ^ val
else:
num2 = num2 ^ val
return num1, num2
if __name__ == "__main__":
print(get_uniques([2, 4, 6, 8, 10, 2, 6, 10]))
print(get_uniques([2, 4, 8, 8, 10, 2, 6, 10]))
print(get_uniques([2, 3, 8, 8, 10, 2, 1, 10]))
"""
SPECS:
TIME COMPLEXITY: O(n)
SPACE COMPLEXITY: O(1)
"""