困っています

フォーラム(掲示板)ルール
フォーラム(掲示板)ルールはこちら  ※コードを貼り付ける場合は [code][/code] で囲って下さい。詳しくはこちら
ハヤテ

困っています

#1

投稿記事 by ハヤテ » 13年前

問題をそのまま書くんで出来れば今日中に教えてください・・・
2進数10110001-2進数00101110の計算を2の補数を利用して計算する
という問題です。全く出来なくて困っています、助けてください

アバター
nullptr
記事: 239
登録日時: 13年前

Re: 困っています

#2

投稿記事 by nullptr » 13年前

http://dixq.net/board/board.html
↑フォラムルールです。


「うまくいきません」という質問は大抵回答に困ります。

  1. 自分は今何がしたくて

  2. どう取り組んで(作ったプログラムはどれで

  3. どのようなエラーやトラブルで困っていて

  4. 自分は何が解らないのか、知りたいのか

  5. 今のCの知識はどの程度なのか

この5点をしっかりと明記して下さい。

そもそも、これってプログラムの問題なのかすら分からないんですが;
これをコードに起こせということでしょうか?
 
 
✜ で C ご ✜
: す + 注 :
¦ か + 文 ¦
?
Is the は :
order C++? ✜
     糸冬   
  ――――――――
  制作・著作 NHK
 
 

たかぎ
記事: 328
登録日時: 14年前
住所: 大阪
連絡を取る:

Re: 困っています

#3

投稿記事 by たかぎ » 13年前

課題の丸投げなので、突き放した回答をします。

コード:

#include <iostream>
#include <bitset>
#include <string>

int main()
{
    std::string a("10110001"), b("00101110");
    unsigned long t = std::bitset<8>(a).to_ulong() - std::bitset<8>(b).to_ulong();

    std::cout << "  " << a << std::endl;
    std::cout << "-)" << b << std::endl;
    std::cout << "----------" << std::endl;
    std::cout << "  " << std::bitset<8>(t) << std::endl;
}
コードの意味は自分で考えてください。
とくに、どこで2の補数を使っているかは、じっくり考えてください。

ハヤテ

Re: 困っています

#4

投稿記事 by ハヤテ » 13年前

2の補数さえ出来ればできるんです。
もう、ここ以外はやったので補数の部分を教えてください・・・

アバター
softya(ソフト屋)
副管理人
記事: 11677
登録日時: 14年前
住所: 東海地方
連絡を取る:

Re: 困っています

#5

投稿記事 by softya(ソフト屋) » 13年前

学王さんと同じ方でしょうか?
名前の統一をお願いします。
by softya(ソフト屋) 方針:私は仕組み・考え方を理解して欲しいので直接的なコードを回答することはまれですので、すぐコードがほしい方はその旨をご明記下さい。私以外の方と交代したいと思います(代わりの方がいる保証は出来かねます)。

たかぎ
記事: 328
登録日時: 14年前
住所: 大阪
連絡を取る:

Re: 困っています

#6

投稿記事 by たかぎ » 13年前

ハヤテ さんが書きました:2の補数さえ出来ればできるんです。
もう、ここ以外はやったので補数の部分を教えてください・・・
では、もう少しわかりやすく...

コード:

#include <iostream>
#include <bitset>
#include <string>

int main()
{
    std::string a("10110001"), b("00101110");
    unsigned long t = std::bitset<8>(a).to_ulong() + -std::bitset<8>(b).to_ulong();

    std::cout << "  " << a << std::endl;
    std::cout << "-)" << b << std::endl;
    std::cout << "----------" << std::endl;
    std::cout << "  " << std::bitset<8>(t) << std::endl;
}
これでどうでしょうか?

beatle
記事: 1281
登録日時: 13年前
住所: 埼玉
連絡を取る:

Re: 困っています

#7

投稿記事 by beatle » 13年前

2の補数は,全ビットを反転させて1を足すだけです.
0101の2の補数は1011です.
0101
ビット反転
1010
1加算
1011

zz

Re: 困っています

#8

投稿記事 by zz » 13年前

似たような投稿がありますが同じ人ですか?
http://detail.chiebukuro.yahoo.co.jp/qa ... 1182046921

閉鎖

“C言語何でも質問掲示板” へ戻る