-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpairs.py
43 lines (34 loc) · 982 Bytes
/
pairs.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
# takes O(nlgn + lgn)
def pairs_slower(k, arr):
# python's sort takes O(nlogn)
arr.sort()
def binary_search(lst, item):
mid = int(len(lst) / 2)
if item == lst[mid]:
return True
elif item != lst[mid] and len(lst) == 1:
return False
elif item < lst[mid]:
return binary_search(lst[:mid], item)
elif item > lst[mid]:
return binary_search(lst[mid:], item)
counter = 0
for i in range(len(arr)):
if binary_search(arr, (arr[i] + k)):
counter += 1
if (arr[i] + k) > arr[-1]:
break
return counter
def pairs(k, arr):
dict = {}
counter = 0
for item in arr:
dict[item] = 1
if (item + k) in dict :
counter += 1
dict[(item + k)] = 1
elif (item - k) in dict :
counter += 1
dict[(item - k)] = 1
return counter
print(pairs(2, [1,5,3,4,2]))