Java Fly

          Java&Oracle
          隨筆 - 12, 文章 - 20, 評論 - 27, 引用 - 0
          數(shù)據(jù)加載中……

          補(bǔ)碼的原理及隨想

          補(bǔ)碼的原理及隨想 - [筆記]

          越早在課堂上學(xué)的東西,越給我以簡單的印象,忘得也越快。而事實上,它們往往是最富有智慧的,即便在我沒忘的時候,也沒有深刻地理解它們。

          嘛是補(bǔ)碼?不少書上扯一堆“取反加1之類的規(guī)則,很不著重點,我覺得核心在于:

          對于范圍為[0,M)的整數(shù)計量系統(tǒng),其模為M。和為M的兩個數(shù)互為補(bǔ)數(shù)。

          如果有兩個整數(shù)a,b[0, M),那么f(a-b)==f(a+c),其中c= M-b,是b的補(bǔ)碼,f是一個映射,定義為:
          當(dāng)0<=x< M,f(x)=x;
          當(dāng)x>= M,f(x)=x % M;
          當(dāng)x<0,f(x)=f(M +x).
          其中%為取余運算(效果同編程語言中的取模運算)

          在計算機(jī)中,f是由溢出隱式實現(xiàn)的,所以天生就有a-b==a+c。這就把減運算轉(zhuǎn)化成了加運算。

          于是,為了便于執(zhí)行減運算,計算機(jī)就把-b表示為其補(bǔ)碼c

          假設(shè)機(jī)器字有n位,那么M=2nc=2n-b

          人在紙上怎么計算2n-b的二進(jìn)制值?2n的原碼就是1后面跟了n0,直接用它減b的原碼不方便,先用2n-1的原碼(n1)減b的原碼,得到的結(jié)果加上1就是2n-b的值了——這就是“取反加1的由來。

          posted on 2007-11-01 10:18 Java Fly 閱讀(1941) 評論(4)  編輯  收藏

          評論

          # re: 補(bǔ)碼的原理及隨想  回復(fù)  更多評論   

          知其然,知其所以然,這種學(xué)習(xí)態(tài)度值得學(xué)習(xí).
          2007-11-12 18:19 | 紫蘇

          # re: 補(bǔ)碼的原理及隨想[未登錄]  回復(fù)  更多評論   

          為什么好多教材都沒有提到模的概念,都是取反加1 這不是糊弄大家嗎?
          2008-01-10 11:52 | fox

          # re: 補(bǔ)碼的原理及隨想[未登錄]  回復(fù)  更多評論   

          當(dāng)x<0時,f(x)=f(M-(-x)%M). 這樣才對吧。
          因為M+x仍有可能為復(fù)數(shù)。
          2008-09-22 23:12 | Tony

          # re: 補(bǔ)碼的原理及隨想  回復(fù)  更多評論   

          也許我們兩個所表達(dá)的關(guān)于補(bǔ)碼的理念應(yīng)該結(jié)合一下,這樣會更加完善啊
          呵呵,歡迎討論啊
          http://blog.chinaunix.net/u2/86948/showart_1849617.html
          2009-03-11 00:40 | caocao

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 平定县| 西城区| 宿州市| 文水县| 正宁县| 乌审旗| 灌南县| 灌云县| 洮南市| 阿图什市| 北川| 南木林县| 沙湾县| 镇康县| 永泰县| 赤峰市| 焦作市| 彩票| 海伦市| 新龙县| 苏尼特右旗| 天津市| 方正县| 遂平县| 德钦县| 临泽县| 静乐县| 东光县| 郓城县| 章丘市| 咸阳市| 类乌齐县| 玉门市| 永善县| 禄丰县| 光泽县| 榆社县| 库尔勒市| 石首市| 苏尼特左旗| 镇沅|