Heim >Backend-Entwicklung >C++ >Wie gehe ich mit negativen Zahlen in Modulo-Operationen in C/C/Obj-C um?

Wie gehe ich mit negativen Zahlen in Modulo-Operationen in C/C/Obj-C um?

DDD
DDDOriginal
2024-11-02 23:10:29874Durchsuche

How to Handle Negative Numbers in Modulo Operations in C/C  /Obj-C?

Umgang mit negativen Zahlen in Modulo-Berechnungen in C/C/Obj-C

In C-basierten Sprachen werden Modulo-Operationen mit dem „%“ verwendet. Der Operator kann beim Umgang mit negativen Zahlen unerwartetes Verhalten zeigen. Insbesondere kann das Ergebnis von dem mathematischer Modulo-Operationen abweichen.

Problemerklärung

Als mathematisches Konzept gibt die Modulo-Division den Rest zurück, wenn eine Zahl durch geteilt wird ein anderer. In C/C/Obj-C legt der Modulo-Operator jedoch Wert darauf, das Vorzeichen des Dividenden (des ersten Operanden) beizubehalten, anstatt einen positiven Rest sicherzustellen. Dies kann zu negativen Ergebnissen führen, selbst wenn die mathematische Division einen positiven Rest ergeben würde.

Betrachten Sie beispielsweise den Ausdruck „(-1) % 8“. Mathematisch gesehen sollte dies 7 ergeben, da 8 einmal mit einem Rest von 7 in -1 geht. In C/C wäre das Ergebnis jedoch -1, da das Vorzeichen der Dividende beibehalten wird.

Lösung mit Implementierungsüberlegungen

Um diese Situation zu beheben, kann eine überarbeitete Version des Modulo-Operators implementiert werden, um negative Zahlen zu berücksichtigen:

<code class="c++">int customMod(int a, int b) {
  if (b < 0) {
    return -customMod(-a, -b);
  }

  int ret = a % b;
  if (ret < 0) {
    ret += b;
  }

  return ret;
}</code>

In dieser optimierten Version, falls vorhanden Wenn der Operanden negativ ist, werden die Vorzeichen beider umgekehrt und der benutzerdefinierte Modulo-Operator wird rekursiv aufgerufen. Nach der Berechnung des Rests prüft es, ob er negativ ist, und addiert den Divisor, um ihn positiv zu machen. Dadurch wird sichergestellt, dass das Endergebnis den korrekten mathematischen Rest beibehält. Zum Beispiel würde customMod(-1, 8) 7 zurückgeben, während customMod(13, -8) -3 zurückgeben würde.

Insgesamt verarbeitet dieser überarbeitete Modulo-Operator effektiv negative Zahlen und erzeugt Ergebnisse, die mit der Mathematik übereinstimmen Modulo-Erwartungen.

Das obige ist der detaillierte Inhalt vonWie gehe ich mit negativen Zahlen in Modulo-Operationen in C/C/Obj-C um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn