雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網(wǎng)!

C語言

當(dāng)前位置:主頁 > 軟件編程 > C語言 >

C++數(shù)據(jù)精度問題的解決方案(對浮點數(shù)保存指定位小數(shù))

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊:

 1、背景

       對浮點數(shù)保存指定位小數(shù)。比如,  1.123456.   要保存1位小數(shù),,調(diào)用方法后, 保存的結(jié)果為: 1.1。 再比如,1.98765,  保存2位小數(shù)的結(jié)果為: 2.00.

2、 解決方案

      A、添加頭文件

#include <sstream> 
#include <iomanip> 

      B、添加命名空間

using namespace std; 

       C、添加函數(shù)

    /************************************************************************/ 
/* 函數(shù)名:round 
/* 函數(shù)功能:數(shù)據(jù)精度計算函數(shù) 
/* 函數(shù)參數(shù):float src:待求精度數(shù)   int bits:精度(0表示保留小數(shù)點后0位小數(shù),1表示保留1位小數(shù),2:表示保留2位小數(shù)) 
/* 函數(shù)返回值:精度求取結(jié)果 
/* Author: Lee 
/************************************************************************/ 
float round(float src, int bits); 

        函數(shù)實現(xiàn)

float CDemo1Dlg::round(float src, int bits) 
{ 
  stringstream ss; 
  ss << fixed << setprecision(bits) << f; 
  ss >> f; 
   return f; 
 
} 

     D、調(diào)用方式

CString str2 = L"99.054"; 
float f2 = (float)_wtof(str2); 
f2 *= 10; 
f2 = this->round(f2, 2); 

    E 、注意

        比如, 1.05,   double在計算機中表示為 1.0499999997, float表示為1.0500000003, 但其實際都是與1.05相等的。
       round方方式對處理的位數(shù)為5的情況有例外,比如: 1.05, 處理的結(jié)果 可能為1.0499999997。 這里寫的是float, 你可以換做其他的類型。自己多測幾次就明白了

總結(jié)

以上所述是小編給大家介紹的C++數(shù)據(jù)精度問題的解決方案(對浮點數(shù)保存指定位小數(shù)),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對我們網(wǎng)站的支持!

上一篇:C++ 中malloc()和free()函數(shù)的理解

欄    目:C語言

下一篇:C語言實現(xiàn)靜態(tài)順序表的實例詳解

本文標(biāo)題:C++數(shù)據(jù)精度問題的解決方案(對浮點數(shù)保存指定位小數(shù))

本文地址:http://www.jygsgssxh.com/a1/Cyuyan/1278.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有