-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathfind-missing-and-repeated-values.py
40 lines (35 loc) · 1.14 KB
/
find-missing-and-repeated-values.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
# Time: O(n^2)
# Space: O(1)
# bit manipulation
class Solution(object):
def findMissingAndRepeatedValues(self, grid):
"""
:type grid: List[List[int]]
:rtype: List[int]
"""
n = len(grid)
a_xor_b = 0
for i in xrange(n**2):
r, c = divmod(i, n)
a_xor_b ^= grid[r][c]^(i+1)
base = a_xor_b&-a_xor_b
result = [0]*2
for i in xrange(n**2):
r, c = divmod(i, len(grid[0]))
result[1 if (i+1)&base != 0 else 0] ^= i+1
result[1 if grid[r][c]&base != 0 else 0] ^= grid[r][c]
if any(x == result[1] for row in grid for x in row):
result[0], result[1] = result[1], result[0]
return result
# Time: O(n^2)
# Space: O(n^2)
import collections
# freq table
class Solution2(object):
def findMissingAndRepeatedValues(self, grid):
"""
:type grid: List[List[int]]
:rtype: List[int]
"""
cnt = collections.Counter(x for row in grid for x in row)
return [next(k for k, v in cnt.iteritems() if v == 2), next(x for x in xrange(1, len(grid)**2+1) if x not in cnt)]