„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie findet man die Zahl in einer Liste, die einem bestimmten Wert am nächsten kommt?

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

Veröffentlicht am 19.11.2024
Durchsuche:887

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

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

Gegeben eine Liste von Ganzzahlen 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:

Verwenden 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))

Verwenden der binären Suche (Halbierungsmethode)

Wenn bekannt ist, dass die Liste sortiert ist, 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 
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3