Comprendre le comportement de l'opérateur modulo avec des valeurs négatives dans les langages de type C
L'opérateur modulo (%) dans les langages dérivés du C, tels que C, C et Obj-C peuvent conduire à des résultats inattendus lorsque vous travaillez avec des nombres négatifs. Cela peut être frustrant, surtout pour ceux qui ont une formation en mathématiques. Dans cette discussion, nous approfondirons le problème et explorerons des solutions pour gérer les valeurs négatives dans l'opération modulo.
Un aspect clé à garder à l'esprit est que l'opération modulo reflète le reste après la division entière. Cependant, pour les nombres négatifs, le signe du reste est défini par l'implémentation, conformément à la norme C. Cette incohérence peut entraîner des résultats surprenants, tels que (-1) % 8 renvoyant -1 au lieu des 7 attendus.
Pour relever ce défi, nous pouvons tirer parti de l'approche suivante :
int mod(int a, int b) {
if (b Cette solution prend en charge les opérandes positifs et négatifs. Il garantit que le reste est toujours positif en ajoutant le diviseur si le reste est négatif. En conséquence, mod(-1, 8) renverra 7, tandis que mod(13, -8) renverra -3, offrant un comportement cohérent et intuitif.
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3