Math.Floor()とMath.Truncate()の違い


422

違いは何であるMath.Floor()Math.Truncate().NETのは?


8
例:Math.Floor(5.4)= 5 Math.Truncate(5.4)= 5
subramani

3
あなたは本当に10年後に奇妙なことをこれが必要ですか?lol
L_Church

1
なぜ10年後に賞金があるのですか?すでに多くの答えがあります。私がここで見逃しているものはありますか?
水たまり

3
この男はたった1つの質問をし、それ以来サイトを去った。彼がいつも知りたかったのはそれだけだと思います。:D
Nikos

回答:


484

Math.Floor切り捨て、Math.Ceiling切り上げ、Math.Truncateゼロに向かって丸めます。このように、Math.TruncateのようなものであるMath.Floor正の数のため、などMath.Ceiling負の数のため。ここに参照があります。

完全をMath.Round期すために、最も近い整数に丸めます。数値が2つの整数のちょうど中間にある場合は、偶数に向かって丸めます。参照。

参照:パックスディアブロの答えを。強くお勧めします!


31
@ Chris、Roundの説明を修正することをお勧めします。丸めには2つの方法(AwayFromZeroとToEven)があり、分数も丸めることができるため、最も近い整数に丸めません。
paxdiablo 2009

1
ですから、元の質問に少しだけ追加してください-Math.Truncateと、10進数または2倍をintにキャストするだけの違いは何ですか?ゼロに向かって丸めるのではないですか?
Noam Gal

8
とはいつ(int)myDouble違います(int)Math.Truncate(myDouble)か?
mpen

2
Mathクラスの(int)とは何ですか?
Lei Yang

386

以下のMSDNの説明については、これらのリンクをたどってください。

  • Math.Floor、負の無限大に切り捨てます。
  • Math.Ceiling、正の無限大に切り上げます。
  • Math.Truncate、ゼロに向かって切り上げまたは切り下げます。
  • Math.Round、最も近い整数または指定した小数点以下の桁数に丸めます。最終桁が偶数になるように丸める( " Round(2.5,MidpointRounding.ToEven)"が2になる)か、ゼロから遠ざかる( " Round(2.5,MidpointRounding.AwayFromZero)"が3になる)など、2つの可能性の間で正確に等距離である場合の動作を指定できます。

次の図と表が役立つ場合があります。

-3        -2        -1         0         1         2         3
 +--|------+---------+----|----+--|------+----|----+-------|-+
    a                     b       c           d            e

                       a=-2.7  b=-0.5  c=0.3  d=1.5  e=2.8
                       ======  ======  =====  =====  =====
Floor                    -3      -1      0      1      2
Ceiling                  -2       0      1      2      3
Truncate                 -2       0      0      1      2
Round (ToEven)           -3       0      0      2      3
Round (AwayFromZero)     -3      -1      0      2      3

Roundそれは小数点以下の特定の番号に丸めることができますという理由だけで、それはそうよりも多くの強力です。他のすべては常に小数点以下をゼロに丸めます。例えば:

n = 3.145;
a = System.Math.Round (n, 2, MidpointRounding.ToEven);       // 3.14
b = System.Math.Round (n, 2, MidpointRounding.AwayFromZero); // 3.15

他の関数では、乗算/除算トリックを使用して同じ効果を達成する必要があります。

c = System.Math.Truncate (n * 100) / 100;                    // 3.14
d = System.Math.Ceiling (n * 100) / 100;                     // 3.15

7
パックス、あなたは間違いがあると思います:Round(AwayFromZero)-3 -2 1 2 3 Math.Round(-1.2、MidpointRounding.AwayFromZero)== -1 Math.Round(0.3、MidpointRounding.AwayFromZero)== 0.0など
dtroy

1
おかげで、@ dtroy、私はそのモードを使用する必要がありませんでした。テキストの場合は正しくドキュメント化しましたが、例が完全に間違っていました。うまくいけば、今は修正されています。
paxdiablo 2009

そのような古い質問にコメントして申し訳ありませんが、私は尋ねなければなりません:「ToEven」を小数点以下2桁に丸めるにはどうすればよいですか?確かに奇数であり、整数にのみ適用されますか?
リチバン2014年

4
@Richiban は、丸められた数値のeven最後の桁のプロパティとして考えます。数値全体が2の倍数でなければならないという意味ではありません。ちなみに、ご返答に時間がかかりすぎて申し訳ありません。私の返事を待っているだけではなかったと思います:-)
paxdiablo

62

Math.Floor() 負の無限大に丸めます

Math.Truncate ゼロに向かって切り上げまたは切り下げます。

例えば:

Math.Floor(-3.4)     = -4
Math.Truncate(-3.4)  = -3

ながら

Math.Floor(3.4)     = 3
Math.Truncate(3.4)  = 3

2
短い例を使った素晴らしく単純な説明。これは、この質問への回答としてマークする必要があります。
nivs1978

44

いくつかの例:

Round(1.5) = 2
Round(2.5) = 2
Round(1.5, MidpointRounding.AwayFromZero) = 2
Round(2.5, MidpointRounding.AwayFromZero) = 3
Round(1.55, 1) = 1.6
Round(1.65, 1) = 1.6
Round(1.55, 1, MidpointRounding.AwayFromZero) = 1.6
Round(1.65, 1, MidpointRounding.AwayFromZero) = 1.7

Truncate(2.10) = 2
Truncate(2.00) = 2
Truncate(1.90) = 1
Truncate(1.80) = 1

29

Math.floor左に
Math.ceilスライド... 右に
Math.truncateスライド... criiiiss crooooss(床/天井は常に0の方向)
Math.roundcha cha、real smooth ...(goest side)

仕事に行こう!(⌐□_□)

左に... Math.floor
今すぐ元に戻して... --
今回は2ホップ...-=2

みんな拍手lap

どれだけ低くできますか?あなたは低く下げることができますか?に至るまでfloor

if (this == "wrong")
    return "i don't wanna be right";

Math.truncate(x)もと同じint(x)です。
正または負の分数を削除すると、常に0に向かっています。


はははいいリミックス。
ダニエルはモニカを

26

それらは正の数と機能的に同等です。違いは、負の数の処理方法にあります。

例えば:

Math.Floor(2.5) = 2
Math.Truncate(2.5) = 2

Math.Floor(-2.5) = -3
Math.Truncate(-2.5) = -2

MSDNのリンク: - Math.Floor方法 - Math.Truncate方法

PS Math.Roundにご注意ください。期待したものとは異なる場合があります。

「標準」の丸め結果を取得するには、以下を使用します。

float myFloat = 4.5;
Console.WriteLine( Math.Round(myFloat) ); // writes 4
Console.WriteLine( Math.Round(myFloat, 0, MidpointRounding.AwayFromZero) ) //writes 5
Console.WriteLine( myFloat.ToString("F0") ); // writes 5

24

これを試してください、例:

Math.Floor() Math.Truncate()の比較

Math.Floor(2.56) = 2
Math.Floor(3.22) = 3
Math.Floor(-2.56) = -3
Math.Floor(-3.26) = -4

Math.Truncate(2.56) = 2
Math.Truncate(2.00) = 2
Math.Truncate(1.20) = 1
Math.Truncate(-3.26) = -3
Math.Truncate(-3.96) = -3

また、恐らくMath.round()

   Math.Round(1.6) = 2
   Math.Round(-8.56) = -9
   Math.Round(8.16) = 8
   Math.Round(8.50) = 8
   Math.Round(8.51) = 9

math.floor()

指定された数以下の最大の整数を返します。MSDN system.math.floor

math.truncate()

数値の整数部分を計算します。MSDN system.math.truncate



15

Math.Floor():指定された倍精度浮動小数点数以下の最大の整数を返します。

Math.Round():値を最も近い整数または指定された小数桁数に丸めます。


1
OPは、Floor()Truncate()ではなくFloor()、との違いについて尋ねましたRound()
ロバートコロンビア

5

Math.floor()つまり、常に切り捨てます。つまり、LESSER整数を返します。一方でround()、最も近い整数を返します。

math.floor()

指定された数値以下の最大の整数を返します。

math.truncate()

数値の整数部分を計算します。


弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.