-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
Copy pathcount-the-number-of-houses-at-a-certain-distance-i.py
46 lines (43 loc) · 1.55 KB
/
count-the-number-of-houses-at-a-certain-distance-i.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
# Time: O(n)
# Space: O(1)
# math, prefix sum, difference array
class Solution(object):
def countOfPairs(self, n, x, y):
"""
:type n: int
:type x: int
:type y: int
:rtype: List[int]
"""
x, y = x-1, y-1
if x > y:
x, y = y, x
diff = [0]*n
for i in xrange(n):
diff[0] += 1+1 # i -> two routes begin
diff[min(abs(i-x), abs(i-y)+1)] += 1 # i -> x -> y, fork one route at x to y
diff[min(abs(i-y), abs(i-x)+1)] += 1 # i -> y -> x, fork one route at y to x
diff[min(abs(i-0), abs(i-y)+1+abs(x-0))] -= 1 # i -> 0, one route ends
diff[min(abs(i-(n-1)), abs(i-x)+1+abs(y-(n-1)))] -= 1 # i -> n-1, one route ends
diff[max(x-i, 0)+max(i-y, 0)+((y-x)+0)//2] -= 1 # i -> x -> ((y-x)+0)//2 <- x, one route ends
diff[max(x-i, 0)+max(i-y, 0)+((y-x)+1)//2] -= 1 # i -> y -> ((y-x)+1)//2 <- y, one route ends
for i in xrange(n-1):
diff[i+1] += diff[i]
return diff
# Time: O(n^2)
# Space: O(1)
# math
class Solution2(object):
def countOfPairs(self, n, x, y):
"""
:type n: int
:type x: int
:type y: int
:rtype: List[int]
"""
x, y = x-1, y-1
result = [0]*n
for i in xrange(n):
for j in xrange(i+1, n):
result[min(abs(i-j), abs(i-x)+1+abs(y-j), abs(i-y)+1+abs(x-j))-1] += 2
return result