Heim >Backend-Entwicklung >C++ >Gibt es eine schnellere Möglichkeit, zu überprüfen, ob eine ganze Zahl innerhalb eines bestimmten Bereichs liegt?
Schnellste Methode, um zu bestimmen, ob eine ganze Zahl zwischen zwei ganzen Zahlen liegt (einschließlich)
Die Bestimmung, ob eine ganze Zahl zwischen zwei anderen ganzen Zahlen liegt, ist eine übliche Methode Operation, und der traditionelle Ansatz beinhaltet die Verwendung von logischem UND und Ungleichung Vergleiche:
x >= start && x <= end
Gibt es jedoch eine schnellere Alternative?
Eine mögliche Optimierung besteht darin, einen einzelnen Vergleich/Zweig zu verwenden. Dieser Ansatz funktioniert, indem die Zahl sowie die Unter- und Obergrenzen in ganze Zahlen ohne Vorzeichen umgewandelt und deren Differenz verglichen werden:
if ((unsigned)(number-lower) <= (upper-lower)) in_range(number);
Warum funktioniert das? Liegt die Zahl unter der Untergrenze, ist die Differenz negativ. Wenn die Zahl innerhalb des Bereichs liegt, ist die Differenz positiv und kleiner oder gleich der Differenz zwischen der Ober- und Untergrenze.
Diese Methode hat mehrere Vorteile:
In der Praxis werden die Zahl und das Intervall auf den Ursprungspunkt übertragen und Das Testen, ob die Zahl innerhalb von [0, D] liegt, wobei D = oben – unten, bildet die Grundlage für diesen effizienten Algorithmus. Negative Zahlen unterhalb der Untergrenze führen zu negativen Werten, während Zahlen über der Obergrenze zu Werten größer als D führen.
Das obige ist der detaillierte Inhalt vonGibt es eine schnellere Möglichkeit, zu überprüfen, ob eine ganze Zahl innerhalb eines bestimmten Bereichs liegt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!