Grad-ProbAsk 板


LINE

(代po) 最近在複習二進位減法的時候有一個地方卡了兩三天 感覺這問題很簡單但是我腦袋一時轉不過來.. 問題就是:要如何判斷二進位用二補數算完後的結果到底是正數還是負數? 我記得之前上計概的時候,學校老師說(還抄在我的筆記上..): (1)最高位元無進位表示結果為負, 若要轉為十進則要用將值以取反2補數還原為負數 而若最高位元有進位時表示結果為正,該進位直接捨棄 例如:算十進位的11-21 => 11 + (-21) =>要把21取2補數再和11相加 11的二進位為:0000 1011 21的二補數為:1110 1011 則: 0000 1011 +) 1110 1011 -----------------------  1111 0110 =>沒有進位,表示結果為負,1111 0110再取一次二補數 =>1111 0110取二補數 = 0000 1001 也就是10,所以答案=-10 沒問題 符合老師上課說的 但是我看到一個反例 如果是 -15-25=>(-15) + (-25) => -15和-25都取二補數並且相加 -15的二補數為:1111 0001 -25的二補數為:1110 0111 則: 1111 0001 +) 1110 0111 ----------------------- 1 1101 1000  | 這個1進位了! 有一個進位的1,如果照老師說的規則,那這個結果應該是正的 但是結果卻是-40,是負的 也就是要把算完的結果(1 1101 1000)整串再取一次二補數然後再加負號 才會變成-40 所以我就有點被搞混了.. 在電腦中,如果要"以運算後的結果"來看是正數還是負數,到底該怎麼看呢? (也就是假設我們一開始不知道這兩個數運算完後到底是正還是負,單純以結果來看) 再麻煩各位替我解答一下了 這裡我卡了好多天 一直想也想不通 謝謝 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 114.43.134.169 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/Grad-ProbAsk/M.1590838733.A.220.html ※ 編輯: g1990822 (114.43.134.169 臺灣), 05/30/2020 19:49:18
1F:推 cossetannie: 看最高位有沒有進位只是考慮有沒有發生overflow 05/31 00:29
2F:→ cossetannie: overflow那結果當然不會對 05/31 00:30
3F:推 cossetannie: 上面好像講錯了 忽略掉吧 如果你只是單純要看正負數 05/31 00:40
4F:→ cossetannie: 直接看sign bit就可以了吧 應該跟進不進位沒什麼關 05/31 00:40
5F:→ cossetannie: 係 05/31 00:40
6F:→ chengaryguan: 若正加正變負,或附加負變正,才考慮overflow,但以 05/31 00:45
7F:→ chengaryguan: 你的舉例,負加負仍為負,因此直接不用管overflow的 05/31 00:46
8F:→ chengaryguan: 那個bit,後面的11011000就是-40在2補數的值了。 05/31 00:46
所以這兩位大大的意思是 做完補數運算後=>"利用進位"先看有沒有overflow =>沒有overflow的話直接看原本的答案來判斷就好嗎? 像是我舉的第一題: 11+ (-21) = 1111 0110 =>"沒進位"也沒有overflow =>答案就是1111 0110 =>把1111 0110做二補數加負號=>-10(十進位) 第二題: -15 + -25 = 1 1101 1000 | 進位的1 =>最左邊有一個進位的1 =>"有進位"但是沒有overflow =>答案就是 1101 1000(不管進位的1了) =>把1101 1000做二補數加負號=>-40(十進位) 簡單來說就是,做完運算之後,"不管有沒有進位","只要沒有overflow", 那答案就是直接這樣算就好了嗎? 謝謝 ※ 編輯: g1990822 (61.230.5.114 臺灣), 05/31/2020 03:11:07
9F:→ chengaryguan: 是的,電腦判斷正負就靠最左邊的bit為0或1,因跐當o 05/31 09:45
10F:→ chengaryguan: verflow等那個bit運算完與結果的最左邊的bit相同(s 05/31 09:45
11F:→ chengaryguan: ign bit),表示沒有發生overflow,結果就是正確的, 05/31 09:45
12F:→ chengaryguan: 以你的例子就是後面那個8個bits直接當結果。 05/31 09:45
13F:推 cossetannie: 進位應該是用來判斷unsiged運算的結果正確與否 05/31 10:17
14F:→ wildwolf: 沒有人發現 8-bit 表示正負數的時候,沒有表示 -40 的方 06/01 08:29
15F:→ wildwolf: 法嗎?一開始就要多一bit signed extension 計算 06/01 08:30
16F:→ cossetannie: 11011000不是-40嗎 06/01 11:09







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:Soft_Job站內搜尋

TOP