日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯網營銷解決方案
聊聊幾個小數取整函數的問題

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

成都創(chuàng)新互聯服務項目包括寧縣網站建設、寧縣網站制作、寧縣網頁制作以及寧縣網絡營銷策劃等。多年來,我們專注于互聯網行業(yè),利用自身積累的技術優(yōu)勢、行業(yè)經驗、深度合作伙伴關系等,向廣大中小型企業(yè)、政府機構等提供互聯網行業(yè)的解決方案,寧縣網站推廣取得了明顯的社會效益與經濟效益。目前,我們服務的客戶以成都為中心已經輻射到寧縣省份的部分城市,未來相信會繼續(xù)擴大服務區(qū)域并繼續(xù)獲得客戶的支持與信任!

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

下面我們依次來看看這幾個函數的特性。

ceil函數

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

 
 
 
 
  1. float ceil ( float arg ); 
  2. double ceil ( double arg ); 

我們可以用下圖來直觀的描述它,空心表示橫坐標Arg不包含所在點的值,實心表示包含所在點的值。

ceil函數

一個例子:

 
 
 
 
  1. #include  
  2. #include  
  3. int main() 
  4.     // ceil 
  5.     std::cout << "ceil(+3.3) = " << std::ceil(+3.3) << '\n' 
  6.               << "ceil(-3.4) = " << std::ceil(-3.4) << '\n' 
  7.               << "ceil(-0.0) = " << std::ceil(-0.0) << '\n' 
  8.               << "ceil(-Inf) = " << std::ceil(-INFINITY) << '\n'; 

結果如下:

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

floor函數

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

 
 
 
 
  1. float floor ( float arg ); 
  2. double floor ( double arg ); 

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

floor函數

再看代碼:

 
 
 
 
  1. #include  
  2. #include  
  3. int main() 
  4.     // floor 
  5.     std::cout << "floor(+3.6) = " << std::floor(+3.6) << '\n' 
  6.               << "floor(-3.2) = " << std::floor(-3.2) << '\n' 
  7.               << "floor(-0.0) = " << std::floor(-0.0) << '\n' 
  8.               << "floor(-Inf) = " << std::floor(-INFINITY) << '\n'; 

結果:

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

round函數

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

 
 
 
 
  1. float round ( float arg ); 
  2. double round ( double arg ); 

同樣的我們可以用圖來描述它:

round

代碼也要有:

 
 
 
 
  1. #include  
  2. #include  
  3.  
  4. int main() 
  5.     // round 
  6.     std::cout << "round(+4.2) = " << std::round(4.2)  << '\n' 
  7.               << "round(+4.5) = " << std::round(4.5)  << '\n' 
  8.               << "round(+4.7) = " << std::round(4.7)  << '\n' 
  9.               << "round(-4.3) = " << std::round(-4.3) << '\n' 
  10.               << "round(-4.5) = " << std::round(-4.5) << '\n' 
  11.               << "round(-4.8) = " << std::round(-4.8) << '\n'; 
  12.   

看結果啦~

 
 
 
 
  1. round(+4.2) = 4 
  2. round(+4.5) = 5 
  3. round(+4.7) = 5 
  4. round(-4.3) = -4 
  5. round(-4.5) = -5 
  6. round(-4.8) = -5 

trunc函數

除了上面幾個取整方式之外,還有另外一個取整方式,我們可以叫“舍尾取整”,實際上它的作用是將整數和小數部分截斷。

 
 
 
 
  1. float trunc ( float arg ); 
  2. double trunc ( double arg ); 

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

圖片看示例:

 
 
 
 
  1. #include  
  2. #include  
  3. int main() 
  4.     // trunc 
  5.     std::cout << "trunc(+2.7) = " << std::trunc(+2.7) << '\n' 
  6.               << "trunc(-2.9) = " << std::trunc(-2.9) << '\n' 
  7.               << "trunc(-0.0) = " << std::trunc(-0.0) << '\n' 
  8.               << "trunc(-Inf) = " << std::trunc(-INFINITY) << '\n'; 

結果如下:

 
 
 
 
  1. trunc(+2.7) = 2 
  2. trunc(-2.9) = -2 
  3. trunc(-0.0) = -0 
  4. trunc(-Inf) = -inf 

最后

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

本文轉載自微信公眾號「Will的大食堂」,可以通過以下二維碼關注。轉載本文請聯系Will的大食堂公眾號。


本文名稱:聊聊幾個小數取整函數的問題
轉載注明:http://www.5511xx.com/article/cdipgsg.html