Python - Rekursion
Durch die Rekursion kann sich eine Funktion selbst aufrufen. Feste Codeschritte werden für neue Werte immer wieder ausgeführt. Wir müssen auch Kriterien festlegen, um zu entscheiden, wann der rekursive Aufruf endet. Im folgenden Beispiel sehen wir einen rekursiven Ansatz für die binäre Suche. Wir nehmen eine sortierte Liste und geben ihren Indexbereich als Eingabe für die rekursive Funktion an.
Binäre Suche mit Rekursion
Wir implementieren den Algorithmus der binären Suche mit Python wie unten gezeigt. Wir verwenden eine geordnete Liste von Elementen und entwerfen eine rekursive Funktion, um die Liste zusammen mit dem Start- und Endindex als Eingabe aufzunehmen. Dann ruft sich die binäre Suchfunktion selbst auf, bis das gesuchte Element gefunden wurde, oder schließt auf seine Abwesenheit in der Liste.
def bsearch(list, idx0, idxn, val):
if (idxn < idx0):
return None
else:
midval = idx0 + ((idxn - idx0) // 2)
# Compare the search item with middle most value
if list[midval] > val:
return bsearch(list, idx0, midval-1,val)
elif list[midval] < val:
return bsearch(list, midval+1, idxn, val)
else:
return midval
list = [8,11,24,56,88,131]
print(bsearch(list, 0, 5, 24))
print(bsearch(list, 0, 5, 51))
Wenn der obige Code ausgeführt wird, wird das folgende Ergebnis erzeugt:
2
None