• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            唐吉訶德

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              5 Posts :: 75 Stories :: 3 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(2)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            這是程序員面試的一道常見題,也是個C++基礎問題。若只在大學里看過幾本基礎的編程入門書,看見這道題可能會覺得奇怪,不就是和0比較嗎,直接拿出來比就是了,其實非也。下文引自google搜索結果,出處不詳,高手可以無視,菜菜留下,記得做好筆記。
            首先給個提示:題目中要求的是零值比較,而非與0進行比較,在C++里“零值”的范圍可就大了,可以是0, 0.0 , FALSE或者“空指針”。
            int型變量 n 與“零值”比較的 if 語句就是:

            if ( n == 0 )

            if ( n != 0 )

            如下寫法均屬不良風格.。

            if ( n )               // 會讓人誤解 n 是布爾變量

            if ( !n   )

             BOOL flag 與“零值”比較的 if 語句:

            根 據布爾類型的語義,零值為“假”(記為FALSE),任何非零值都是“真”(記為TRUE)。TRUE 的值究竟是什么并沒有統一的標準。例如Visual C++ 將TRUE 定義為1,而Visual Basic 則將TRUE 定義為-1。所以我們不可以將布爾變量直接與TRUE、FALSE 或者1、0 進行比較。

            標準答案:

            if ( flag )

            if ( !flag )

            如下寫法均屬不良風格。

            if (flag == TRUE)

            if (flag == 1 )

            if (flag == FALSE)

            if (flag == 0)

            float x 與“零值”比較的 if 語句:
            千萬要留意,無論是float 還是double 類型的變量,都有精度限制,都不可以用“==”或“!=”與任何數字比較,應該設法轉化成“>=”或“<=”形式。(為什么?文章之后有詳細的討論,可參考)

            假設浮點變量的名字為x,應當將

            if (x == 0.0)         // 隱含錯誤的比較

            轉化為

            if ((x>=-EPSINON) && (x<=EPSINON))

            其中EPSINON 是允許的誤差(即精度)。

            標準答案示例:

            const float EPSINON = 0.00001;

            if ((x >= - EPSINON) && (x <= EPSINON)

            如下是錯誤的寫法。

            if (x == 0.0)

            if (x != 0.0) 

            char *p 與“零值”比較的 if 語句:

            標準答案:

            if (p == NULL)

            if (p != NULL)

            如下寫法均屬不良風格。

            if (p == 0)         // 容易讓人誤解p是整型變量

            if (p != 0)

            if (p)                 // 容易讓人誤解p是bool型變量

            if (!p)

            以 上的不良風格很多都能通過編譯,但是語句并不能很好的表達與零值進行比較的邏輯依據。一般的,如果想用 if 語句判斷一個變量的真假,應該直接使用if(var)、if(!var),表明此 if 語句的功能為“邏輯”判斷;如果想用 if 語句判斷一個數值型變量(short、int、long等),應該用if(var==0),表明此 if 語句是將變量與0進行“數值”上的比較;而檢視指針是否為空則適宜用if(var==NULL),這是一種很好的編程習慣。

            浮點型變量并不精確,所以不可將float變量用“==”或“!=”與數字比較,應該設法轉化成“>=”或“<=”形式。如果寫成if (x == 0.0),則判為錯,得0分。以下給出詳細原因:
            浮點數在內存中的存貯機制和整型數不同,有舍入誤差,在計算機中用以近似表示任意某個實數。具體的說,這個實數由一個整數或定點數(即尾數)乘以某個基數(計算機中通常是2)的整數次冪得到,這種表示方法類似于基數為10的科學記數法。
            所以浮點數在運算過成功運算通常伴隨著因為無法精確表示而進行的近似或舍入。但是這種設計的好處是可以在固定的長度上存儲更大范圍的數。
            例如,一個指數范圍為±4的4位十進制浮點數可以用來表示43210,4.321或0.0004321,但是沒有足夠的精度來表示432.123和43212.3(必須近似為432.1和43210)。當然,實際使用的位數通常遠大于4。
            所以浮點數不能夠判斷相等,像 if(x==0)的這樣的編碼是不總是正確的,我們在判斷浮點數相等時,推薦用范圍來確定,若x在某一范圍內,我們就認為相等,至于范圍怎么定義,要看實際情況而已了,float,和double 各有不同
            所以const float EPSINON = 0.00001;
            if ((x >= - EPSINON) && (x <= EPSINON) 這樣判斷是可取的
            至于為什么取0.00001,可以自己按實際情況定義

            再看下面CSDN上的回答

            引用
            #define   E   1.0E-6  

            float   x   與“零值”比較的if  
            -----------------------  

            浮點數是不可以直接比較大小的,因為是非精確存儲,只能設置一個精度,然后在允許誤差內的就認為是相等的;對浮點型數比較的時候用==是不對的  

            #define   E   0.000001      

            fabs((a+b)+c)   -   ((b+a)+c))
            posted on 2010-08-26 08:36 心羽 閱讀(574) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
            日批日出水久久亚洲精品tv| 国产精品女同久久久久电影院| 国产ww久久久久久久久久| 国产成人精品久久亚洲| 国内高清久久久久久| 国产农村妇女毛片精品久久| 久久精品国产亚洲AV忘忧草18| 精品久久久久久亚洲精品| 久久免费香蕉视频| 国产精品久久永久免费| 精品久久久久久无码人妻蜜桃| 伊人色综合久久天天人手人婷 | 久久久精品国产Sm最大网站| 无码人妻久久一区二区三区蜜桃| 99久久精品毛片免费播放| 97久久婷婷五月综合色d啪蜜芽| 狠狠人妻久久久久久综合蜜桃| 精品国产VA久久久久久久冰| 一本久久知道综合久久| 久久伊人精品青青草原日本| 久久国产精品久久精品国产| 97久久国产综合精品女不卡| 精品久久久久成人码免费动漫 | 亚洲va中文字幕无码久久不卡 | 国产精品成人精品久久久| 久久婷婷五月综合色奶水99啪| 久久亚洲sm情趣捆绑调教| 亚洲欧美一区二区三区久久| 精品久久久久中文字| 久久高清一级毛片| 久久精品国产精品亚洲| 久久综合综合久久97色| 亚洲国产精品热久久| 99国产欧美久久久精品蜜芽| 久久亚洲欧美国产精品 | 狠狠色婷婷综合天天久久丁香| 999久久久免费精品国产| 精品久久久久久久| 国产精品久久久久久久午夜片 | 久久水蜜桃亚洲av无码精品麻豆 | 欧美激情精品久久久久久久|