青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 15,  comments - 0,  trackbacks - 0

 

 

 本次試驗我組主要是想通過運用補碼來表示整數,我主要的工作是將十進制整數轉化成補碼及其加減運算和溢出的討論。

一、原理

    人類習慣使用十進制數進行數值計算,而計算機則采用二進制,所以為了讓計算機幫助人類計算,首先要把十進制數轉換為二進制數。本次說明以最簡單的8位定點整數為例,分析了計算機存儲和計算數值的方法。

整數有正負之分,但計算機卻只認得“0”“1”,不知道符號“+”“-”,所以有必要用“0”“1”來表示“+”“-”。人們規定用“0”表示“+”,用“1”表示“-”

       這樣,就可以表示出計算機能識別的整數了,把符號數值化后的二進制數稱為機器數,相對應的,符號沒有數值化(即仍用“+”“-”號表示)的二進制數稱為真值。計算機只能處理機器數。

(一)原碼

       機器數有三種編碼形式,分別稱為:原碼,補碼和反碼。其實篇頭已經介紹了機器碼的一種形式——原碼,它的特點是有效數值部分照抄真值,符號“+”“-”分別用“0”“1”表示。

例如:

+6D,它的真值是+000 0110(注意:8位二進制數最高位是符號位,所以其真值只有7 位),對應的原碼就是0000 0110

-6D,它的真值是-000 0110,對應的原碼就是1000 0110

原碼表示法比較直觀,它的數值部分就是該數的絕對值,而且與真值的轉換十分方便。

(二)補碼

    機器數的補碼可由原碼得到。如果機器數是正數,則該機器數的補碼與原碼一樣;如果機器數是負數,則該機器數的補碼是對它的原碼(除符號位外)各位取反,并在未位加1而得到的。設有一數X,則X的補碼表示記作[X

那補碼是如何編碼的,對于十進制+6。它真值是+000 0110,原碼是0000 0110。用數學表達式來表示真值和原碼的關系,這就是:

設機器字長為N位,真值為X,則:

[X]  = X         0 <= X < 2^(n-1)

[X]  = 2^(n-1) - X -2^(n-1) < X <= 0   

例如:[+6]  = 6,把6轉換為8位二進制數,就得到原碼0000 0110。(本此說明的最后將會提供一個把十進制數轉換為機器碼的C++算法實現)。

[-6]  = 2^(8-1) – (-6) = 256 + 6 = 262,,把262轉換為8位二進制數,就得到原碼1000 0110。即最高位本來是0,加了一個2^(8-1)后,最高位就變成1了。

同樣給出補碼的數學表達式:

[X]  = X         0 <= X < 2^(n-1)

[X]  = 2^n + X   -2^(n-1) <= X < 0

和原碼一樣,正數的補碼就等于真值。負數的補碼則該機器數的補碼是對它的原碼(除符號位外)各位取反,并在未位加1而得到的。

(三)反碼

機器數的反碼可由原碼得到。如果機器數是正數,則該機器數的反碼與原碼一樣;如果機器數是負數,則該機器數的反碼是對它的原碼(符號位除外)各位取反而得到的。設有一數X,則X的反碼表示記作[X反碼和原碼的關系很緊密,反碼表示法規定:正數的反碼與其原碼相同;負數的反碼是對其原碼逐位取反,但符號位除外。

 

四)補碼的加法運算規則

 [XY]= [X]補+[Y]補該式表明,當有符號的兩個數采用補碼形式表示時,進行加法運算可以把符號位和數值位一起進行運算(若符號位有進位,則丟掉),結果為兩數之和的補碼形式。

例如用補碼進行下列運算:(+33)補+(+15)補;(+33)補+(-15)補。

計算這樣一個補碼數時,首先要記得把相應的補碼數寫成二進制數(有符號位)。如圖所示的就是以上兩個補碼加法運算式。最終的結果分別是[+48]補和[+18] 補。

 

00100001   +33          00100001    +33

 

00001111    +15         11110001     -15

---------------------------------------------------------------------------

00110000    +48        100010010     +18

 兩個補碼加法運算示例

(五)補碼的減法運算規則
[X-Y]
=[X]+[-Y]

該式表明,求[X-Y]補可以用[X]補與[-Y]補相加來實現。

 [-Y]補是對減數進行求負操作。一般稱已知[Y]補求得[-Y]補的過程叫變補或求負。已知[+Y]補求[-Y]補的規則是全部位(含符號位)按位取反后再加1

例如:已知[+15]=00001111B,則[-15]=11110000B+1=11110001B
或:0- [+15]=0–10001111B=11110001B

現在例舉補碼減法運算示例。仍假設X=+33Y=+15,現要求[X-Y]補。

先求得[X]=00100001B[Y]=00001111B,根據以上介紹的補碼負操作規則,可以得到[-Y]=11110001B。然后再用[X]補+[-Y]補公式即可得到最終的[X–Y]補。運算過程如圖所示。如果是X= -33Y= -15,如果仍要求[X-Y]補,則同樣需要求[-Y]補,也即[--15]補,實際上是要求[+15]的補碼。因為已知了[-15]=11110001B,根據前面介紹的補碼負操作規則,可以很快得出[15]=00001111B。這樣[X-Y]補就等于[-33]+[+15]補,運算過程如圖2-15右圖所示。

001000001     X】補                 11011111        -33

 

+1111000 1      -Y】補             + 00001111       +15

-----------------------------------------------------------------------------------------

100010010      +18                11101110        -18

 兩個補碼減法運算示例

(六)溢出討論

 下面的問題是如何檢查加減運算中的溢出問題。通常有三種表述方式(說法):
  (1) 兩個符號相同的補碼數相加,如果和的符號與加數的符號相反,或兩個符號相反的補碼數相減,差的符號與減數的符號相同,都屬于運算結果溢出。這種判別方法比較復雜,要區別加還是減兩種不同運算情況,還要檢查結果的符號與其中一個操作數的符號的同異,故很少使用;

  (2) 兩個補碼數相加減時,若最高數值位向符號位送的進位值與符號位送向更高位的進位值不相同,也是運算結果溢出。

  (3) 在采用雙符號位(如定點小數的模4補碼)運算時,若兩個符號位的得值不同(0110)則是溢出。01表明兩個正數相加,結果大于機器所能表示的最大正數,稱為"上溢"10表明兩個負數相加,結果小于機器所能表示的最小負數,稱為"下溢";雙符號位的高位符號位,不管結果溢出否,均是運算結果正確的符號位,這個結論在乘法運算過程中是很有實際意義的。請注意,在采用雙符號位的方案中,在寄存器和內存儲器存儲數據時,只需存一位符號,雙符號位僅用在加法器線路部分。


 

二、思路

  本次實驗的的思路主要是根據數值間的轉化設計,運用原理的思想將十進制轉化成二進制,進而求出原碼和補碼。

首先,定義一個函數void Binary(int n)將正整數轉化成二進制(負數的比較特別,后面用另外的函數求得)其中的變量n是輸入的十進制正整數。其轉化方式主要是運用除2取余法!將結果保留在一維數組中,方便以后使用。其次定義了輸出函數void Print(int a[])主要是輸出最后求出的二進制、原碼。由于補碼的輸出特別些,我目前想不到更好的方法就另加啦個輸出補碼的輸出函數void Printbm(int a[]),其主要原因是將最高位置1(用了||運算符)。最后,就是再定義了一個求負數的二進制的函數void Nbinary(int a[])主要是對應負數的二進制的各位作啦相應變換。其一負數的二進制是其正數二進制的各位取反再加1,其二就是對進位的處理,從低到高一次掃描,發現2時就將其置1,再將其下一位加1,依次類推,則可以求出負整數的二進制碼,再運用相應的運算求出其原碼,補碼。

程序的結尾就是運用main()函數調用函數輸出結果。

三、流程圖

四、存在問題

對于本次試驗程序,本人覺得存在很多的不足,很多地方自己覺得繁瑣但又不知道怎樣修整比較好,也就是勉強能調試出結果。在很多方法上應該有更簡便的方法,但卻不知道怎么修改。望老師指點、修整。

五、程序源代碼

#include "iostream"

Using namespace std;

const int MAX=32;

 

int a[MAX]={0};

int c[MAX]={0};

void Delete(int a[])//主要是清除運行時修改的,將其賦成¨

 {

          for(int i=0;i<MAX;i++)

                    a[i]=0;

 }

void Binary(int a[],int n)//正數的二進制轉換

{

         Delete(a);

         int b,i=0;

 while(n>0)//除取余法

   {

         b=n%2;

    n=(n-b)/2;

    a[i]=b;

    i++;

   }

}

 void Print(int a[])//º出函數

 { 

          

          for( int i=MAX-1;i>=0;i--)

                   {

               cout<<a[i];

             }

 }

 void Nbinary(int a[],int x)//負數º的二進制轉換函¡

 {

                   Delete(a);

          int b,i=0;

          x=-x;

 while(x>0)//除取¨余法

   {

         b=x%2;

    x=(x-b)/2;

    a[i]=b;

    i++;

   }

          for(int i=0;i<MAX;i++)//相應位取反

         {

                   if(a[i]==0)

                             a[i]=1;

                    else

                             a[i]=0;

          }

          a[0]=a[0]+1;//取反¤¨再在¨末位加¨一,轉換成負數的二進制碼

          for(int i=0;i<MAX;i++)

          {

                    if(a[MAX-1]==2)

                             a[MAX-1]=0;

                    else

              if(a[i]==2)//處理相¨¨¨的進位?

                             {

                                      a[i]=0;

                    a[i+1]=a[i+1]+1;

                    }

                    else

                             break;

          }    

 }

 

 void Printf(int x)

{

if(x>=0)

         {

                   Binary(a,x);//yºyÌ?t??¨ª1?°??

                   cout<<"t??êo";

        Print(a);

                   cout<<endl;

                   cout<<1?êo";

        Print(a);

                   cout<<endl;

}

else

    {

            Nbinary(a,x);//oºyÌ?1?¨ªt??°2°?¨´

            cout<<"t??êo";

            Print(a);

            cout<<endl;

            cout<<1?êo";

        Print(a);

                   cout<<endl;  

}

}

 void add(int a[],int b[])//1?¨®¤¡§

{

         int d[MAX]={0};

         for(int i=0;i<MAX;i++)

         {

                   d[i]=d[i]+a[i]+b[i];

                   if(d[i]==2)//ä|¤¨ª¨¤¨®¨®Ì???

                             {

                                      d[i]=0;

                           d[i+1]=d[i+1]+1;

                         }

                   else if(d[i]==3){

                            d[i]=1;

                       d[i+1]=d[i+1]+1;

                   }

         }

         for(int i=MAX-1;i>=0;i--){

                   cout<<d[i];}

         cout<<endl;

}

 void sub(int a[],int b[])//1??¤¡§

 {

          for(int i=0;i<MAX;i++)//¨¤®|?¨?¤¡ä

         {

                   if(b[i]==0)

                             b[i]=1;

                    else

                             b[i]=0;

          }

          b[0]=b[0]+1;//¨?¤¡ä¨®¨´¨²??¨®°?ê?Áa?¨¦oºyÌ?-[Y]1

          for(int i=0;i<MAX;i++)

          {

                    if(b[MAX-1]==2)

                             b[MAX-1]=0;

                    else

              if(b[i]==2)//ä|¤¨ª¨¤¨®¨®Ì???

                             {

                                      b[i]=0;

                    b[i+1]=b[i+1]+1;

                    }

                    else

                             break;

          }    

          add(a,b);

 }

int _tmain(int argc, _TCHAR* argv[])

{

int x,y,z;

 

cout<<" Please input the first integer :";

cin>>x;

Printf(x);//º??̨²°??ºy

for(int i=0;i<MAX;i++){

         c[i]=a[i];

}

cout<<" Please input the second integer :";

cin>>y; 

Printf(y);//º??̨²t?ºy

cout<<endl;

cout<<"The Result of the addition (a+b) is :";

add(c,a);

cout<<"TheResult of the subtraction (a-b) is :";

sub(c,a);

 return 0;

system("pause");

}

 

 

 

 

 

 

 

 

 

 

六、程序結果

 

 

 

 

王秋林

3100200089

posted on 2010-09-26 15:44 王秋林 閱讀(1400) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2010年9月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

常用鏈接

留言簿(1)

隨筆檔案(15)

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            国产精品网站在线| 亚洲天天影视| 亚洲性感激情| 99热这里只有精品8| 最近中文字幕日韩精品| 亚洲欧洲一区二区三区| 一本大道久久a久久综合婷婷 | 在线视频精品一区| 一区二区三区四区在线| 欧美视频免费在线| 亚洲欧美精品| 美国十次了思思久久精品导航| 欧美国产第一页| 国产毛片一区二区| 亚洲欧洲精品天堂一级| 亚洲欧美日本在线| 欧美高清视频一区二区三区在线观看| 亚洲欧洲在线免费| 亚洲精品久久久久久下一站| 午夜欧美精品久久久久久久| 老巨人导航500精品| 欧美视频一区| 亚洲电影天堂av| 性久久久久久久久| 亚洲激情不卡| 久久久99国产精品免费| 欧美日韩伦理在线| 樱桃成人精品视频在线播放| 亚洲一区二区精品在线| 欧美大尺度在线观看| 亚洲一区二区三区高清| 欧美成人小视频| 国产一区二区在线观看免费| 亚洲久久在线| 免费成人毛片| 性欧美暴力猛交另类hd| 欧美午夜精品久久久| 亚洲国产日韩欧美在线99| 久久本道综合色狠狠五月| 日韩亚洲欧美一区| 欧美大片国产精品| 依依成人综合视频| 久久精品国产成人| 亚洲少妇中出一区| 欧美欧美午夜aⅴ在线观看| 在线观看精品一区| 久久偷窥视频| 欧美在线视频在线播放完整版免费观看| 欧美日韩视频在线一区二区| 最新亚洲一区| 亚洲国产精品电影在线观看| 免费亚洲电影| 亚洲精品中文字幕在线观看| 亚洲国产欧美不卡在线观看| 鲁大师影院一区二区三区| 国模精品一区二区三区色天香| 欧美亚洲免费电影| 亚洲欧美在线播放| 国内不卡一区二区三区| 久久五月天婷婷| 久久久精品日韩欧美| 激情视频一区| 欧美成人福利视频| 猫咪成人在线观看| 999在线观看精品免费不卡网站| 你懂的亚洲视频| 另类图片国产| 日韩一区二区精品| 亚洲欧美另类综合偷拍| 老巨人导航500精品| 欧美在线你懂的| 黄色小说综合网站| 欧美高清视频在线| 欧美日韩美女在线观看| 午夜精品一区二区三区四区 | 亚洲在线国产日韩欧美| 日韩视频在线观看| 欧美日韩视频专区在线播放 | 99在线热播精品免费| 欧美日韩小视频| 欧美一区成人| 欧美在线一二三四区| 亚洲国产精品成人va在线观看| 欧美高清在线视频| 欧美日韩中文在线| 久久成人久久爱| 美女黄毛**国产精品啪啪| 日韩西西人体444www| 亚洲视频免费在线| 亚洲电影免费在线观看| 亚洲天堂成人| 亚洲区一区二区三区| 亚洲专区在线| 亚洲国产视频一区| 亚洲小说欧美另类婷婷| 亚洲电影第三页| 亚洲小少妇裸体bbw| 亚洲国产高清aⅴ视频| 一区二区三区 在线观看视频| 伊人久久大香线蕉综合热线| 一区二区高清视频在线观看| 狠狠久久亚洲欧美| 9久草视频在线视频精品| 好吊色欧美一区二区三区四区| 亚洲精品国产系列| 激情丁香综合| 亚洲综合丁香| 夜夜爽www精品| 老司机久久99久久精品播放免费| 性色av一区二区三区| 欧美寡妇偷汉性猛交| 久久青青草综合| 国产麻豆日韩| 一区二区三区波多野结衣在线观看| 在线观看免费视频综合| 亚洲专区免费| 亚洲永久免费| 欧美人成在线| 亚洲高清视频在线观看| 激情亚洲成人| 欧美在线地址| 久久成人免费视频| 国产精品v欧美精品v日韩 | 欧美经典一区二区三区| 免费观看在线综合| 国产亚洲欧美一区| 久久久91精品国产一区二区三区| 亚洲欧美另类在线| 一区二区三区四区蜜桃| 欧美韩日一区二区| 欧美高清视频免费观看| 在线免费不卡视频| 久久精品一二三区| 久久久噜噜噜久久狠狠50岁| 国产伦精品一区二区三区高清版| 一区二区av在线| 亚洲一区激情| 国产精品久久久久秋霞鲁丝| 99视频精品全部免费在线| 一本一本大道香蕉久在线精品| 欧美高清成人| 亚洲日本视频| 亚洲天堂成人| 国产精品亚洲视频| 午夜欧美精品| 欧美不卡激情三级在线观看| 亚洲国产另类久久久精品极度| 麻豆国产精品777777在线| 欧美电影在线| 一本色道久久99精品综合 | 亚洲男女毛片无遮挡| 欧美在线日韩| 尤物视频一区二区| 欧美承认网站| 一区二区三区国产精华| 欧美一区二区免费| 国产综合色在线| 欧美国产一区视频在线观看| 日韩视频久久| 久久久久久久一区| 亚洲经典在线看| 国产精品对白刺激久久久| 欧美一区二区精美| 欧美激情一区二区| 性做久久久久久免费观看欧美| 精品福利电影| 欧美日韩亚洲高清| 久久成人国产| 日韩一级在线观看| 久久久久久夜| 99国产精品久久| 国产日韩精品一区二区三区在线 | 国产一区二区三区的电影| 久久久欧美精品sm网站| 亚洲精品视频在线观看免费| 欧美在线视频观看免费网站| 亚洲欧洲在线视频| 国产精品视频免费一区| 欧美国产日韩视频| 午夜精品剧场| 亚洲精品专区| 欧美国产高清| 久久久精品一品道一区| 一区二区三区高清不卡| 精久久久久久久久久久| 国产精品大全| 欧美成人精品三级在线观看| 午夜精品理论片| 一区二区冒白浆视频| 亚洲第一综合天堂另类专| 久久国产精品久久久久久久久久| 亚洲精品少妇| 永久555www成人免费| 国产精品一香蕉国产线看观看| 欧美怡红院视频| 国产日韩精品一区| 中日韩午夜理伦电影免费| 最新国产の精品合集bt伙计| 久久九九国产精品| 麻豆精品视频在线观看|