加入星計(jì)劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長(zhǎng)期合作伙伴
立即加入
  • 正文
    • ceil函數(shù)
    • floor函數(shù)
    • round函數(shù)
    • trunc函數(shù)
  • 推薦器件
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請(qǐng)入駐 產(chǎn)業(yè)圖譜

幾個(gè)小數(shù)取整函數(shù)

04/28 11:05
1673
閱讀需 7 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論

在c++的cmath庫(kù)中提供了幾個(gè)小數(shù)取整的函數(shù)ceil() floor() round() trunc,我們可以根據(jù)不同的場(chǎng)景去選用它們。

  • ceil函數(shù):向上取整
  • floor函數(shù):向下取整
  • round函數(shù):四舍五入取整
  • trunc函數(shù):舍尾取整

下面我們依次來(lái)看看這幾個(gè)函數(shù)的特性。

ceil函數(shù)

ceil函數(shù)如下定義,函數(shù)返回不小于參數(shù)arg的最小整數(shù),即向上取整。

float ceil ( float arg );
double ceil ( double arg );
我們可以用下圖來(lái)直觀的描述它,空心表示橫坐標(biāo)Arg不包含所在點(diǎn)的值,實(shí)心表示包含所在點(diǎn)的值。


ceil函數(shù)

一個(gè)例子:

#include <cmath>
#include <iostream>
int main()
{
// ceil
std::cout << "ceil(+3.3) = " << std::ceil(+3.3) << 'n'
<< "ceil(-3.4) = " << std::ceil(-3.4) << 'n'
<< "ceil(-0.0) = " << std::ceil(-0.0) << 'n'
<< "ceil(-Inf) = " << std::ceil(-INFINITY) << 'n';
}

結(jié)果如下:

ceil(+3.3) = 4
ceil(-3.4) = -3
ceil(-0.0) = -0
ceil(-Inf) = -inf

floor函數(shù)

floor函數(shù)如下定義,函數(shù)返回不大于arg的最大整數(shù)值,即向下取整。

float floor ( float arg );
double floor ( double arg );

其取值方法我們可以看下圖:


floor函數(shù)

再看代碼:

#include <cmath>
#include <iostream>
int main()
{
// floor
std::cout << "floor(+3.6) = " << std::floor(+3.6) << 'n'
<< "floor(-3.2) = " << std::floor(-3.2) << 'n'
<< "floor(-0.0) = " << std::floor(-0.0) << 'n'
<< "floor(-Inf) = " << std::floor(-INFINITY) << 'n';
}

結(jié)果:

floor(+3.6) = 3
floor(-3.2) = -4
floor(-0.0) = -0
floor(-Inf) = -inf

round函數(shù)

round函數(shù)是我們最常用的取整方式,通過(guò)四舍五入方式取整,其定義如下:

float round ( float arg );
double round ( double arg );

同樣的我們可以用圖來(lái)描述它:


round

代碼也要有:

#include <iostream>
#include <cmath>

int main()
{
// round
std::cout << "round(+4.2) = " << std::round(4.2) << 'n'
<< "round(+4.5) = " << std::round(4.5) << 'n'
<< "round(+4.7) = " << std::round(4.7) << 'n'
<< "round(-4.3) = " << std::round(-4.3) << 'n'
<< "round(-4.5) = " << std::round(-4.5) << 'n'
<< "round(-4.8) = " << std::round(-4.8) << 'n';

}

看結(jié)果啦~

round(+4.2) = 4
round(+4.5) = 5
round(+4.7) = 5
round(-4.3) = -4
round(-4.5) = -5
round(-4.8) = -5

trunc函數(shù)

除了上面幾個(gè)取整方式之外,還有另外一個(gè)取整方式,我們可以叫“舍尾取整”,實(shí)際上它的作用是將整數(shù)和小數(shù)部分截?cái)唷?/p>

float trunc ( float arg );
double trunc ( double arg );

從圖上可以看出,這個(gè)函數(shù)的作用是將整數(shù)部分保留而舍去小數(shù)部分。

看示例:

#include <cmath>
#include <iostream>
int main()
{
// trunc
std::cout << "trunc(+2.7) = " << std::trunc(+2.7) << 'n'
<< "trunc(-2.9) = " << std::trunc(-2.9) << 'n'
<< "trunc(-0.0) = " << std::trunc(-0.0) << 'n'
<< "trunc(-Inf) = " << std::trunc(-INFINITY) << 'n';
}

結(jié)果如下:

trunc(+2.7) = 2
trunc(-2.9) = -2
trunc(-0.0) = -0
trunc(-Inf) = -inf

最后

以上就是c++中提供的幾個(gè)取整函數(shù)的說(shuō)明和使用方法,我們一定要熟知其特性而選擇正確的函數(shù),在大量的數(shù)據(jù)運(yùn)算中,使用不同的函數(shù)進(jìn)行取整,最終的運(yùn)算結(jié)果往往會(huì)有著很大的差異。

推薦器件

更多器件
器件型號(hào) 數(shù)量 器件廠商 器件描述 數(shù)據(jù)手冊(cè) ECAD模型 風(fēng)險(xiǎn)等級(jí) 參考價(jià)格 更多信息
AFBR-5715APZ 1 Broadcom Limited Transceiver, 830nm Min, 860nm Max, 1250Mbps(Tx), LC Connector, Panel Mount, ROHS COMPLIANT
暫無(wú)數(shù)據(jù) 查看
PS2701-1-F3-A 1 NEC Electronics Group Transistor Output Optocoupler, 1-Element, 3750V Isolation, LEAD FREE, PLASTIC, SOP-4
$0.74 查看
SN74AVC32T245ZKER 1 Texas Instruments 32-Bit Dual-Supply Bus Transceiver with Configurable Voltage Translation and 3-State Outputs 96-LFBGA -40 to 85

ECAD模型

下載ECAD模型
$3.65 查看

相關(guān)推薦

電子產(chǎn)業(yè)圖譜