Maison >développement back-end >C++ >Comment gérer les nombres négatifs en arithmétique modulaire pour une indexation correcte des tableaux ?

Comment gérer les nombres négatifs en arithmétique modulaire pour une indexation correcte des tableaux ?

Barbara Streisand
Barbara Streisandoriginal
2025-01-13 13:27:42769parcourir

How to Handle Negative Numbers in Modular Arithmetic for Correct Array Indexing?

Arithmétique modulaire et indices négatifs

Les opérations modulo standard (%) sur des entiers négatifs peuvent produire des résultats inattendus lorsqu'elles sont utilisées pour l'indexation de tableaux. Le reste peut être négatif, conduisant à des valeurs d'index invalides. Pour garantir des indices de tableau positifs corrects, nous avons besoin d'une fonction modulo modifiée.

Une solution courante consiste à utiliser cette formule :

<code>GetArrayIndex(i, arrayLength) = (i % arrayLength + arrayLength) % arrayLength</code>

Cela garantit un index positif dans la plage [0, arrayLength - 1], quel que soit le signe de l'entrée i.

Fonction Modulo personnalisée

Pour un code plus propre, une fonction mod personnalisée est utile :

<code class="language-java">public static int mod(int x, int m) {
    return (x % m + m) % m;
}</code>

Cette fonction gère les restes négatifs en ajoutant m pour garantir un résultat positif.

Fonction Modulo optimisée

Pour une efficacité améliorée (moins d'opérations modulo), envisagez cette alternative :

<code class="language-java">public static int mod(int x, int m) {
    int r = x % m;
    return r < 0 ? r + m : r;
}</code>

Cette version vérifie directement si le reste r est négatif, en ajoutant m uniquement lorsque cela est nécessaire.

Exemples

En utilisant l'une ou l'autre des fonctions mod personnalisées, nous obtenons le comportement attendu de l'index de tableau :

GetArrayIndex(4, 3) == 1 GetArrayIndex(3, 3) == 0 GetArrayIndex(2, 3) == 2 GetArrayIndex(1, 3) == 1 GetArrayIndex(0, 3) == 0 GetArrayIndex(-1, 3) == 2 GetArrayIndex(-2, 3) == 1 GetArrayIndex(-3, 3) == 0 GetArrayIndex(-4, 3) == 2

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!

Déclaration:
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