- ベストアンサー
補数の質問
noname#7273の回答
ビット数が3ビット限定の場合、3_(10)=011_(2)の1の補数は、100_(2)です。 (ちなみに、「1」(=基数2-1)の補数とは(擬補数ともいう)、桁ごとに足すと、互いに補い合って、 111_(2)になる数のこと。だから0,1反転する。) また、3_(10)=011_(2)の2の補数は、101_(2)です。 (ちなみに、基数「2」の補数とは(真補数ともいう)、足すと、互いに補い合って、 基数の桁数乗=2の3乗=8_(10)=1000_(2)になる数のこと。だから0,1反転して1足す。) ともに011と書いてあるのは、教科書が間違っているのでしょう。 注:a_(10)やb_(2)は、それぞれaは10進数、bは2進数という意味です。 また「+3の2の補数」や「+3の1の補数」という言い方は、間違いではありません。 たとえば、このように、1つの整数データを3ビットで表すシステムで、 内部表現形式として「符号なし整数」を使えば、0~2の3乗-1=7までの8通りの整数を表せます。 これに対し、内部表現として「負数を表すのに、2の補数表現を使う」ことにすれば、 (たとえば、「-3」を表すのに、「+3の2の補数表現101を対応させる」ということ) -2の2乗=-4 ~ 2の2乗-1=3までの8通りの整数を表せるようになる。 これによって、「3を引く」あるいは「-3を足すこと」は、「3の2の補数101を足すこと」となり、 (例:5-3=101+101=1010(ただし最左端の1はこぼれて)=010=2) 引き算も足し算でできる、つまり減算回路を使わずに加算回路だけで 四則演算ができるという利点を生んでいるのです。 参考まで。 内部表現として、「最左端ビットを符号ビット(0のとき正、1のとき負)として使用し、 右2ビットを符号なし整数として読み取ることにすれば」(つまり絶対値表現法) -3 ~ +3の7通りの整数を表せるようになる。 このとき、ゼロは+0と-0の2通りの表現をもつ。
関連するQ&A
- 補数について質問です。「次の10進数を8ビットの2の補数に変換せよ」(
補数について質問です。「次の10進数を8ビットの2の補数に変換せよ」(1)-111 まず絶対値をとり111にする。次に111を2進数で表す。0001 0001 0001となりますが、8ビットの2の補数に直すため0001 0001 0001の部分は8桁にしなくてはいけませんが、12桁になってしまいます。こういう場合どうすればいいのですか?
- ベストアンサー
- その他(学問・教育)
- 2の補数について
情報処理試験(基本情報)用の考え方という前提でお聞きします。 「負数を2の補数形式で表現する2進数の計算で・・・・」という問題がよくあります。 この問題文の中で「10101」などの数(これは5ビットの符号付2進数とします) として記述されているものは、もう2の補数になっていると考えていいのでしょうか? それともこれを、今から2の補数に直すのですか? (もし直すのであれば、最上位ビットの符号が変わるのでしょうか?) 違う言い方をしてみますと「A」の2の補数が「-A」だとしたら、 「-A」の2の補数は「A」になるんでしょうか? それとも「そんな表現はない。-Aの時点ですでに2の補数だ」という ことになるのでしょうか? 解りにくくてすみません。
- ベストアンサー
- その他(プログラミング・開発)
- 2に補数
10進数から2進数を2の補数にする時はビット反転して1を足すとできますが、2進数から10進数を2の補数にするときも同じくビット反転して1を足すと正解の答えが出るのですが、そのやり方でいいのでしょうか?
- 締切済み
- ハードウェア・サーバー
- 2の補数を使った計算
ある計算機があり、2の補数を「ビット反転して1を加算する」方法とするときに10進数の計算「100-80」を2の補数を使って計算する場合は16進数で表すと幾つと幾つの加算になるのでしょうか?? 2の補数を使うというのがよくわからないのですが・・・
- ベストアンサー
- その他([技術者向] コンピューター)
- 補数について教えてください!
情報処理技術者試験の内容なんですが、やり方も理解できず悩んでいます。教えてください。 その1. 2の補数を使って解きなさい 0110 -)0111 ------------ その2. 次の2進数は2の補数であらわした負の値である。符号付きの10進数に変換しなさい。 1) 1001 2) 1010 3) 1111 4) 1000 その3. 次の10進数を2の補数(4ビット)に変換しなさい。 1)-6 2)-3 3)-5 4)-4 本を見ながら解いているのですがいまいち理解できません。お手数お掛けしますが、解る方がいらっしゃいましたら解説付で教えてくださると助かります!よろしくお願いいたします!
- ベストアンサー
- その他(プログラミング・開発)
- 補数について質問
以下はJavaの参考書に掲載されている補数についての問題です。 疑問点にお答えいただけましたら幸いです。 次の10進数の補数を8桁の2進数で求めなさい A 15 B 0 C 1 質問1:Bについて、10進数の補数が0となっていますが、こんなのありえるんですか? 補数の定義は、「ある数 A に加えると、和の桁がひとつ上がる最小の数」ということなので、Bならある数がAが100でそれに加える数が0ということでしょうか? 質問2:質問1で記した定義に従い、補数15のある数Aとは85ですか? 質問3:「次の10進数の補数を8桁の2進数で求めなさい」という問題、そもそもどういう意図があるんですか?何故10進数の補数を8桁の2進数で求めさせるんですか? 質問4:この問題、10進数の補数を8桁の2進数に変換する問題かと思いきや、この10進数の補数を2進数に変換し、さらにその変換した2進数を補数にしたものが答えとなっています。 何故ですか?問題文おかしいような、、、 僕が読解を間違えたのでしょうか?
- ベストアンサー
- Java
- 補数ということばの意味
補数ということばの意味 正確には計算機科学の質問なのですが、カテゴリがないのでここに質問しました。 コンピューターで負の数を表すときに、補数表現を使うことがあります。二進数の負の数を表すときに、"1の補数で表す"というときにはビット反転を行い、"2の補数で表す"というときにはビット反転プラス1を行うということはわかるのですが、"1の補数"や"2の補数"ということばの意味がわかりません。何で、"1の"とか"2の"というのですか?
- ベストアンサー
- 数学・算数
- 2の補数の計算について
C言語のプログラム中で得られた10進数の値を,固定長16ビットの2進数に変換したいと考えています. しかしながら,得られた10進数の値が負数であった場合,それを負数と判断し,2の補数として出力したいのですが,なかなかいい方法が思いつきません… 例えば処理中で -1.915098 といったような10進数の値を2進数に変換し,先頭の1ビットが正負符号の2の補数として表現するためにはどのように記述すればよいでしょうか? 簡単で構いませんので,記述例も書いていただけると助かります…
- ベストアンサー
- C・C++・C#