Wie findet man die Zahl in einer Liste, die einem bestimmten Wert am nächsten kommt?

DDD
Freigeben: 2024-11-09 17:48:02
Original
607 Leute haben es durchsucht

How do you find the closest number in a list to a given value?

Finden der Zahl in einer Liste, die einem gegebenen Wert am nächsten kommt

Gegeben eine Liste mit ganzen Zahlen und eine Zielzahl, besteht die Aufgabe darin, die Zahl in der Liste zu finden, die dem Ziel am nächsten ist. Dieses Problem kann mit verschiedenen Ansätzen gelöst werden:

Verwendung von Min Distance

Wenn die Reihenfolge der Elemente in der Liste nicht garantiert ist, kann die Funktion min() mit dem Schlüsselparameter verwendet werden. Diese Methode ermittelt den Mindestabstand zwischen jedem Element und dem Ziel und gibt das Element mit dem Mindestabstand zurück:

def takeClosest(myList, myNumber):
    return min(myList, key=lambda x: abs(x - myNumber))
Nach dem Login kopieren

Verwendung der binären Suche (Bisektionsmethode)

Wenn die Liste bekannt ist sortiert werden, kann die binäre Suche angewendet werden, um die nächstgelegene Zahl effizienter in O(log n)-Zeit zu finden:

def takeClosest(myList, myNumber):
    low = 0
    high = len(myList) - 1
    while low <= high:
        mid = (low + high) // 2
        if myList[mid] == myNumber:
            return myList[mid]
        elif myList[mid] < myNumber:
            low = mid + 1
        else:
            high = mid - 1
    return min([myList[low], myList[high]], key=lambda x: abs(x - myNumber))
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie findet man die Zahl in einer Liste, die einem bestimmten Wert am nächsten kommt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage