C#のFloorメソッドとTruncateメソッドで、切り捨てを行うサンプルです。
目次
説明 | 切り捨てる(Floorメソッド) |
サンプル | 小数第一位で切り捨てる |
小数第二位または小数第三位で切り捨てる | |
1の位または10の位で切り捨てる | |
FloorメソッドとTruncateメソッドの違い |
切り捨てる(Floorメソッド)
public static double Floor(double a) |
- Floorメソッドは、小数第一位で切り捨てます。
- 少数第一位以外を対象とする場合は、値を10倍にしたり1/10にする等の操作で求めることができます。
- staticメソッドなのでインスタンスの生成は不要です。
- 引数はdouble型で戻り値もdouble型です。
- Floorは床という意味です。
小数第一位で切り捨てる
using System;
class Test1
{
static void Main()
{
// 小数第一位で切り捨て
double a = 2.26;
Console.WriteLine(Math.Floor(a)); // 2
// 小数第一位で切り捨て
double b = 2.82;
Console.WriteLine(Math.Floor(b)); // 2
// マイナス値の場合
double c = -2.82;
Console.WriteLine(Math.Floor(c)); // -3
}
}
Floorメソッドで小数第一位を切り捨てています。
16行目は、マイナスの値の場合です。
小数第二位または小数第三位で切り捨てる
using System;
class Test1
{
static void Main()
{
double a = 12.262;
// 小数第二位で切り捨て
Console.WriteLine((Math.Floor(a * 10)) / 10); // 12.2
// 小数第三位で切り捨て
Console.WriteLine((Math.Floor(a * 100)) / 100); // 12.26
}
}
9行目は、小数第二位で切り捨てています。以下の操作です。
1.対象の値に10を掛けます。(12.262 * 10 = 122.62)
2.Floorメソッドを使用して小数点以下で切り捨てます。(122.62 → 122)
3.対象の値を再度10で割ります。(122 / 10 = 12.2)
1の位または10の位で切り捨てる
using System;
class Test1
{
static void Main()
{
double a = 122.2;
// 1の位で切り捨て
Console.WriteLine((Math.Floor(a / 10)) * 10); // 120
// 10の位で切り捨て
Console.WriteLine((Math.Floor(a / 100)) * 100); // 100
}
}
9行目は、1の位で切り捨てています。以下の操作です。
1.対象の値を10で割ります。(122.2 / 10 = 12.22)
2.floorメソッドを使用して小数点以下で切り捨てます。(12.22 → 12)
3.対象の値を再度10で掛けます。(12 * 10 = 120)
以下はMicrosoftのMathクラスFloorメソッドのリンクです。
https://docs.microsoft.com/ja-jp/dotnet/api/system.math.floor?view=netframework-4.8#System_Math_Floor_System_Double_
FloorメソッドとTruncateメソッドの違い
FloorメソッドとTruncateメソッドの違いです。
using System;
class Test1
{
static void Main()
{
// 小数第一位で切り捨て
double a = 2.26;
Console.WriteLine(Math.Floor(a)); // 2
Console.WriteLine(Math.Truncate(a)); // 2
// 小数第一位で切り捨て
double b = 2.82;
Console.WriteLine(Math.Floor(b)); // 2
Console.WriteLine(Math.Truncate(b)); // 2
// マイナス値の場合
double c = -2.82;
Console.WriteLine(Math.Floor(c)); // -3
Console.WriteLine(Math.Truncate(c)); // -2
}
}
Truncateメソッドは、Floorメソッドと同じく小数第一位で切り捨てます。
違いは、17行目のマイナスの値の場合です。
Floorメソッドは、負の無限大方向になります。
Truncateメソッドは、小数部の桁を破棄します。
以下はMicrosoftのMathクラスTruncateメソッドのリンクです。
https://docs.microsoft.com/ja-jp/dotnet/api/system.math.truncate?view=netframework-4.8#System_Math_Truncate_System_Double_
関連の記事