浮點數比較

2021-08-26 11:52:54 字數 752 閱讀 7044

由於計算機中浮點數並不是精確表示,所以兩個浮點數不能直接比較,而是要在乙個誤差範圍內比較。

有的文章還要用相對誤差比較。我用到地方都只需要絕對誤差比較就行了。絕對誤差 eps=1e-8

#define  eps 1e-8

#pragma inline=forced

int double_cmp_biger( double data1,double data2 )

#pragma inline=forced

int double_cmp_smaller( double data1,double data2 )

#pragma inline=forced

int double_cmp_equar_biger( double data1,double data2 )

#pragma inline=forced

int double_cmp_equar_smaller( double data1,double data2 )

#pragma inline=forced

int double_cmp_equar_no( double data1,double data2 )

#pragma inline=forced

int double_cmp_equar( double data1,double data2 )

#pragma inline=forced

int cmp_double(double a,double b) // 小 -1 等 0 大 1

浮點數比較

在數 算當中經常會涉及到判斷兩個數是否相等的情況 對於整數很好處理 a b這樣的乙個語句就可以解決全部的問題 但是對於浮點數是不同的 首先,浮點數在計算機當中的二進位制表達方式就決定了大多數浮點數都是無法精確的表達的 現在的計算機大部分都是數字計算機,不是模擬機,數字機的離散化的資料表示方法自然無法...

浮點數比較

部分 思路來自網路。fxxki整理發布。double變數以帶符號的 ieee 64 位 8 個位元組 雙精度浮點數形式儲存 它可以表示十進位制的15或16位有效數字.負值取值範圍為 1.79769313486231570e 308 到 4.94065645841246544e 324,正值取值範圍為...

浮點數比較

0 我們來看乙個程式 include int main else 1 執行結果 可以看出,我們輸入的2.3和計算出來的 4.6 2 相等,這個沒有問題。但是如果遇到下面這個問題 3 我們再來看一段程式 include include define eqs 1e 8 define equal a,b ...