Maison > développement back-end > C++ > Existe-t-il un moyen plus rapide de vérifier si un entier se situe dans une plage donnée ?

Existe-t-il un moyen plus rapide de vérifier si un entier se situe dans une plage donnée ?

Barbara Streisand
Libérer: 2024-12-10 03:28:21
original
959 Les gens l'ont consulté

Is There a Faster Way to Check if an Integer Falls Within a Given Range?

Le moyen le plus rapide de déterminer si un entier est compris entre deux entiers (inclus)

Déterminer si un entier se situe entre deux autres entiers est une pratique courante opération, et l'approche traditionnelle implique l'utilisation du ET logique et de l'inégalité comparaisons :

x >= start && x <= end
Copier après la connexion

Cependant, existe-t-il une alternative plus rapide ?

Une optimisation potentielle consiste à utiliser une seule comparaison/branche. Cette approche fonctionne en convertissant le nombre et les limites inférieure et supérieure en entiers non signés et en comparant leur différence :

if ((unsigned)(number-lower) <= (upper-lower))
    in_range(number);
Copier après la connexion

Pourquoi cela fonctionne-t-il ? Si le nombre est inférieur à la limite inférieure, la différence sera négative. Si le nombre est compris dans la plage, la différence sera positive et inférieure ou égale à la différence entre les bornes supérieure et inférieure.

Cette méthode présente plusieurs avantages :

  • Réduit Instructions de branchement (une seule comparaison nécessaire).
  • Prédiction de branchement améliorée (la même branche est prise quelle que soit la position du numéro par rapport au plage).
  • Performances améliorées grâce au pré-calcul de la différence entre les limites supérieure et inférieure (minimisation des contributions de temps).

En pratique, traduire le nombre et l'intervalle au point d'origine et tester si le nombre se situe entre [0, D], où D = supérieur - inférieur, constitue la base de cet algorithme efficace. Les nombres négatifs en dessous de la limite inférieure se traduisent par des valeurs négatives, tandis que les nombres au-dessus de la limite supérieure se traduisent par des valeurs supérieures à D.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal