std::floor, std::floorf, std::floorl
提供: cppreference.com
ヘッダ <cmath> で定義 | ||
(1) | ||
float floor (float arg ); | ||
float floorf(float arg ); | (C++11以上) | |
double floor (double arg ); | (2) | |
(3) | ||
longdouble floor (longdouble arg ); | ||
longdouble floorl(longdouble arg ); | (C++11以上) | |
double floor ( 整数型 arg ); | (4) | (C++11以上) |
1-3)
arg
より大きくない最も大きな整数値を計算します。目次 |
[編集]引数
arg | - | 浮動小数点値 |
[編集]戻り値
エラーが発生しなければ、 arg
より大きくない最も大きな整数値、すなわち ⌊arg⌋ が返されます。
戻り値
引数
[編集]エラー処理
math_errhandling で規定されている通りにエラーが報告されます。
処理系が IEEE 浮動小数点算術 (IEC 60559) をサポートしている場合、
- 現在の丸めモードは効果を持ちません。
arg
が ±∞ であれば、それが変更されずに返されます。arg
が ±0 であれば、それが変更されずに返されます。arg
が NaN であれば、 NaN が返されます。
[編集]ノート
非整数の有限な値を丸めるとき、 FE_INEXACT が発生するかもしれません (が要求されているわけではありません)。
すべての標準の浮動小数点フォーマットにおいて、最も大きな表現可能な浮動小数点値は正確な整数であるため、この関数それ自体はオーバーフローすることはありません。 しかし任意の整数型 (std::intmax_t も含みます) は、整数変数に格納するとき、結果がオーバーフローするかもしれません。
[編集]例
Run this code
#include <cmath>#include <iostream>int main(){std::cout<<std::fixed<<"floor(+2.7) = "<< std::floor(+2.7)<<'\n'<<"floor(-2.7) = "<< std::floor(-2.7)<<'\n'<<"floor(-0.0) = "<< std::floor(-0.0)<<'\n'<<"floor(-Inf) = "<< std::floor(-INFINITY)<<'\n';}
出力:
floor(+2.7) = 2.000000 floor(-2.7) = -3.000000 floor(-0.0) = -0.000000 floor(-Inf) = -inf
[編集]関連項目
(C++11)(C++11) | 指定された値より小さくない最も近い整数を返します (関数) |
(C++11)(C++11)(C++11) | 指定された値より絶対値が大きくない最も近い整数を返します (関数) |
(C++11)(C++11)(C++11)(C++11)(C++11)(C++11)(C++11)(C++11)(C++11) | 最も近い整数を返します。 ちょうど中間の場合はゼロから離れる方向に丸めます (関数) |
floor の C言語リファレンス |