std::ceil, std::ceilf, std::ceill
提供: cppreference.com
ヘッダ <cmath> で定義
|
||
(1) | ||
float ceil ( float arg ); |
||
float ceilf( float arg ); |
(C++11以上) | |
double ceil ( double arg ); |
(2) | |
(3) | ||
long double ceil ( long double arg ); |
||
long double ceill( long double arg ); |
(C++11以上) | |
double ceil ( 整数型 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 も含みます) は、整数変数に格納するとき、結果がオーバーフローするかもしれません。
(double 引数に対する) この関数は、以下のコードで実装されているかのように (ただし FE_INEXACT を発生させない自由を除いて) 動作します。
#include <cmath> #include <cfenv> #pragma STDC FENV_ACCESS ON double ceil(double x) { double result; int save_round = std::fegetround(); std::fesetround(FE_UPWARD); result = std::rint(x); // or std::nearbyint std::fesetround(save_round); return result; }
[編集] 例
Run this code
#include <cmath> #include <iostream> int main() { std::cout << std::fixed << "ceil(+2.4) = " << std::ceil(+2.4) << '\n' << "ceil(-2.4) = " << std::ceil(-2.4) << '\n' << "ceil(-0.0) = " << std::ceil(-0.0) << '\n' << "ceil(-Inf) = " << std::ceil(-INFINITY) << '\n'; }
出力:
ceil(+2.4) = 3.000000 ceil(-2.4) = -2.000000 ceil(-0.0) = -0.000000 ceil(-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) |
最も近い整数を返します。 ちょうど中間の場合はゼロから離れる方向に丸めます (関数) |
(C++11)(C++11)(C++11) |
現在の丸めモードを使用して最も近い整数に丸めます (関数) |
(C++11)(C++11)(C++11)(C++11)(C++11)(C++11)(C++11)(C++11)(C++11) |
現在の丸めモードを使用して最も近い整数に丸めますが、結果が異なる場合は例外を発生します (関数) |
ceil の C言語リファレンス
|