-
Notifications
You must be signed in to change notification settings - Fork 95
/
040.py
54 lines (40 loc) · 1.29 KB
/
040.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
45
46
47
48
49
50
51
52
53
54
"""
Problem:
Given an array of integers where every integer occurs three times except for one
integer, which only occurs once, find and return the non-duplicated integer.
For example, given [6, 1, 3, 3, 3, 6, 6], return 1. Given [13, 19, 13, 13], return 19.
Do this in O(N) time and O(1) space.
"""
from typing import List
def get_unique(arr: List[int]) -> int:
# Sum the bits in same positions for all the numbers modulo with 3 provides the
# unique number's bit
unique_elem = 0
mask = 1
# iterate through all the bits (considering a 64 bit integer)
for _ in range(64):
sum_i_pos_bits = 0
# calculating the sum of the bits in the current position
for elem in arr:
if elem & mask != 0:
sum_i_pos_bits = sum_i_pos_bits + 1
# updating the unique element
if sum_i_pos_bits % 3 == 1:
unique_elem = unique_elem | mask
# updating mask
mask = mask << 1
return unique_elem
if __name__ == "__main__":
arr = [3, 3, 2, 3]
print(get_unique(arr))
arr = [13, 19, 13, 13]
print(get_unique(arr))
arr = [6, 1, 3, 3, 3, 6, 6]
print(get_unique(arr))
arr = [12, 1, 3, 1, 1, 2, 3, 2, 2, 3]
print(get_unique(arr))
"""
SPECS:
TIME COMPLEXITY: O(n)
SPACE COMPLEXITY: O(1)
"""