forked from matthewsamuel95/ACM-ICPC-Algorithms
-
Notifications
You must be signed in to change notification settings - Fork 0
/
InterpolationSearch.py
127 lines (113 loc) · 1.08 KB
/
InterpolationSearch.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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
#Interpolation Search
#Better than binary search as it returns a closer value of pos on each iteration.
#pos=low +[x-arr[low]*(high-low)/arr[high]-arr[low]]
#iterative implememtation of interpolation search
def interpolationSearch(L,e):
low=0
high=len(L)-1
while low<=high and e >=L[low] and e <=L[high]:
pos=low + int((high-low)/(L[high]-L[low])*(e-L[low]))
print(pos)
if L[pos]==e:
return pos
if L[pos]<e:
low=pos+1
if L[pos]>e:
high=pos-1
return -1
L = [123,
134,
149,
169,
210,
219,
229,
234,
239,
245,
257,
275,
277,
281,
286,
295,
304,
315,
331,
334,
338,
349,
352,
366,
385,
391,
392,
401,
413,
436,
442,
453,
480,
499,
501,
505,
509,
511,
516,
521,
527,
536,
560,
562,
568,
589,
601,
636,
648,
649,
659,
660,
666,
678,
689,
700,
733,
739,
754,
755,
776,
798,
808,
809,
818,
828,
834,
842,
846,
856,
857,
858,
859,
869,
889,
891,
893,
895,
900,
918,
930,
934,
949,
953,
963,
979,
980,
989,
991,
]
e = 8931# Element to be searched
index = interpolationSearch(L,e)
if index != -1:
print("Element found at index",index)
else:
print("Element not found")