整数以外のモジュラス除算が失敗する理由
数学では、モジュロ演算子 % で表されるモジュラス除算は、剰余を求めます。ある整数を別の整数で除算し、結果を指定された範囲に事実上「ラップアラウンド」します。ただし、C などのプログラミング言語では、この操作は整数以外のオペランドに対しては機能せず、エラーが発生します。
整数の剰余について
整数の場合、剰余演算は直感的に理にかなっています。たとえば、13 を 5 で割ると、商 2 と余り 3 が得られます。これは、5 が 13 にちょうど 2 回適合し、3 の余りが残るためです。
実数への拡張数値
剰余の概念を浮動小数点数、またはより一般的には実数に拡張すると、次のようになります。合併症。 5.2 を 2.3 で割ることを考えてみましょう。数学的には、結果は約 2.2609 になります。ただし、モジュラス演算子をオペランドに直接適用すると、異なる結果が得られます。
C では、オペランドが整数ではないため、5.2 % 2.3 はコンパイラ エラーになります。これは、C 標準では実数の整数商を計算するハイブリッド演算が定義されていないためです。
標準ライブラリ関数
この問題に対処するために、C 標準ではライブラリは 2 つの関数を提供します: fmod と剰余.
指定されたコード サンプルの問題を解決するには、fmod 関数を使用できます。
fmod 関数はオペランドが同じであることを期待していることに注意してください。型なので、必要に応じて double にキャストする必要があります。
以上がなぜ C ではモジュラスが非整数で機能しないのでしょうか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。