-
Notifications
You must be signed in to change notification settings - Fork 96
/
271.py
60 lines (46 loc) · 1.39 KB
/
271.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
55
56
57
58
59
60
"""
Problem:
Given a sorted list of integers of length N, determine if an element x is in the list
without performing any multiplication, division, or bit-shift operations.
Do this in O(log N) time.
"""
from typing import List
def fibo_search(arr: List[int], val: int) -> int:
# fibo search to search an element in a sorted array in O(log(n)) time [without
# multiplication, division, or bit-shift operations]
length = len(arr)
if length == 0:
return 0
fib_N_2 = 0
fib_N_1 = 1
fibNext = fib_N_1 + fib_N_2
while fibNext < len(arr):
fib_N_2 = fib_N_1
fib_N_1 = fibNext
fibNext = fib_N_1 + fib_N_2
index = -1
while fibNext > 1:
i = min(index + fib_N_2, (length - 1))
if arr[i] == val:
return i
fibNext = fib_N_1
if arr[i] < val:
fib_N_1 = fib_N_2
index = i
elif arr[i] > val:
fib_N_1 = fib_N_1 - fib_N_2
fib_N_2 = fibNext - fib_N_1
if (fib_N_1 and index < length - 1) and (arr[index + 1] == val):
return index + 1
return -1
if __name__ == "__main__":
print(fibo_search([1, 3, 5, 7, 9], 3))
print(fibo_search([1, 3, 5, 7, 9], 1))
print(fibo_search([1, 3, 5, 7, 9], 7))
print(fibo_search([1, 3, 5, 7, 9], 6))
print(fibo_search([1, 3, 5, 7, 9], 0))
"""
SPECS:
TIME COMPLEXITY: O(log(n))
SPACE COMPLEXITY: O(1)
"""