Diferença entre Math.Floor () e Math.Truncate ()

votos
363

Qual é a diferença entre Math.Floor()e Math.Truncate()em .NET?

Publicado 01/08/2008 em 01:59
fonte usuário
Em outras línguas...                            


10 respostas

votos
429

Math.Floorarredonda para baixo, Math.Ceilingarredonda para cima, e Math.Truncaterodadas para zero. Assim, Math.Truncateé como Math.Floorpara números positivos, e como Math.Ceilingpara números negativos. Aqui é a referência .

Para completar, Math.Roundarredonda para o número inteiro mais próximo. Se o número é exatamente a meio caminho entre dois números inteiros, então ele rodadas para o mesmo um. Referência.

Veja também: A resposta de Pax Diablo . Altamente recomendado!

Respondeu 01/08/2008 em 13:26
fonte usuário

votos
349

Siga estes links para as descrições do MSDN de:

  • Math.Floor, Que arredonda para baixo para o infinito negativo.
  • Math.Ceiling, Que arredonda-se para a infinidade positiva.
  • Math.Truncate, Que arredonda para cima ou para baixo para zero.
  • Math.Round, Que arredonda para o número inteiro mais próximo ou número especificado de casas decimais. Você pode especificar o comportamento se é exatamente equidistante entre duas possibilidades, como o arredondamento de modo que o último dígito é ainda ( " Round(2.5,MidpointRounding.ToEven)'tornar-se 2) ou de modo que é mais longe de zero (' Round(2.5,MidpointRounding.AwayFromZero)" tornar-se 3).

O diagrama e tabela que se segue pode ajudar a:

-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

Note-se que Roundé muito mais poderoso do que parece, simplesmente porque ele pode arredondar para um número específico de casas decimais. Todos os outros arredondar a zero decimais sempre. Por exemplo:

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

Com as outras funções, você tem que usar multiplicar trapaça / dividir para conseguir o mesmo efeito:

c = System.Math.Truncate (n * 100) / 100;                    // 3.14
d = System.Math.Ceiling (n * 100) / 100;                     // 3.15
Respondeu 24/02/2009 em 03:39
fonte usuário

votos
41

Math.Floor() rodadas para o infinito negativo

Math.Truncate arredonda para cima ou para baixo para zero.

Por exemplo:

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

enquanto

Math.Floor(3.4)     = 3
Math.Truncate(3.4)  = 3
Respondeu 19/07/2011 em 04:56
fonte usuário

votos
37

Alguns exemplos:

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
Respondeu 05/08/2008 em 12:01
fonte usuário

votos
19

Eles são funcionalmente equivalentes com números positivos. A diferença está na forma como eles lidam com números negativos.

Por exemplo:

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

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

Ligações MSDN: - Método Math.Floor - Método Math.Truncate

PS Cuidado com Math.Round pode não ser o que você espera.

Para obter o arredondamento resultado use "padrão":

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
Respondeu 02/01/2015 em 13:09
fonte usuário

votos
18

Math.Floor()rodadas "em direção ao infinito negativo" em conformidade com a norma IEEE 754 secção 4.

Math.Truncate() rounds "para o número inteiro mais próximo a zero."

Respondeu 07/06/2012 em 19:15
fonte usuário

votos
12

math.floor()

Retorna o maior inteiro menor ou igual ao número especificado.

MSDN system.math.floor

math.truncate()

Calcula a parte integrante de um número.

MSDN system.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

Além disso 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
Respondeu 12/02/2016 em 09:12
fonte usuário

votos
11

Math.Floor(): Retorna o maior inteiro menor ou igual ao número de ponto flutuante de precisão dupla especificado.

Math.Round(): Rondas um valor para o número inteiro mais próximo ou para o número especificado de dígitos fracionários.

Respondeu 19/09/2013 em 12:44
fonte usuário

votos
6

Math.floorsliiiide à esquerda ...
Math.ceilsliiiide para a direita ...
Math.truncatecriiiiss crooooss (piso / ceil sempre para 0)
Math.roundcha cha, bens suave ... (ir para o lado mais próximo)

Vamos ao trabalho! (⌐ □ _ □)

Para a esquerda ... Math.floor
Leve de volta agora agora ... --
Dois pulos este tempo ...-=2

Todo mundo bate palmas ✋✋

Quão baixo você pode ir? Você pode ir lá em baixo? Todo o caminho para o floor?

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

Math.truncate(x)também é a mesma que int(x).
removendo uma fração positiva ou negativa, você está sempre em direcção a 0.

Respondeu 11/02/2018 em 15:03
fonte usuário

votos
1

Mat.floor () sempre arredondar para baixo ie., Ele retorna inteiro menores. Enquanto round () irá retornar o número inteiro mais próximo

Respondeu 17/07/2018 em 07:14
fonte usuário

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more