[解決済み】数値を2進数で表示(coutを使用)するには?
2022-04-03 16:25:04
質問
私は大学でOSについての講義を受けていて、2進数から16進数、10進数から16進数などへの変換方法を学んでいますが、今日はちょうど符号付き/符号なし数字が2の補数(~数字+1)を使ってメモリに格納される方法を学びました。
紙で行う演習がいくつかあるので、先生に提出する前に自分の答えを確認できるようにしたいです。最初の数回の練習問題ではC++のプログラムを書きましたが、今は次の問題でどうやって自分の答えを検証したらよいか行き詰っています。
char a, b;
short c;
a = -58;
c = -315;
b = a >> 3;
そして、バイナリ表現を表示する必要があります
メモリ内
の
a
,
b
と
c
.
紙の上でやってみたところ、次のような結果が得られました(2の補数以降の数字のメモリ上の2進数表現はすべて)。
a = 00111010 (charなので1byte)
b = 00001000 (文字なので1バイト)
c = 11111110 11000101 (ショートなので、2バイト)
私の答えを確認する方法はありますか?それとも、各ステップを自分でコーディングしなければならないのでしょうか(2の補数を計算し、バイナリに変換する)?後者はそれほど時間がかからないと思いますが、そうするための標準的な方法があるのかどうか気になります。
どのように解決するのですか?
最も簡単な方法は、おそらく
std::bitset
を表す値にストリーミングし、それを
cout
.
#include <bitset>
...
char a = -58;
std::bitset<8> x(a);
std::cout << x << '\n';
short c = -315;
std::bitset<16> y(c);
std::cout << y << '\n';
関連
-
[解決済み】Visual Studio 2015で「非標準の構文。'&'を使用してメンバーへのポインターを作成します」エラー
-
[解決済み] [Solved] Error C1083: Cannot open include file: 'stdafx.h'
-
[解決済み】浮動小数点例外エラーが発生する: 8
-
[解決済み】Visual Studio 2013および2015でC++コンパイラーエラーC2280「削除された関数を参照しようとした」が発生する
-
[解決済み】オブジェクト引数のない非静的メンバ関数の呼び出し コンパイラーエラー
-
[解決済み】C++ - ステートメントがオーバーロードされた関数のアドレスを解決できない。
-
[解決済み] to_string は std のメンバーではない、と g++ が言っている (mingw)
-
[解決済み】変数やフィールドがvoid宣言されている
-
[解決済み] 32ビット整数のセットビットの数を数えるには?
-
[解決済み] cout を使って double 値を完全な精度で表示するにはどうすればよいですか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】 unsigned int vs. size_t
-
[解決済み】getline()が何らかの入力の後に使用されると動作しない 【重複あり
-
[解決済み】LLVMで暗黙のうちに削除されたコピーコンストラクタの呼び出し
-
[解決済み】C-stringを使用すると警告が表示される。"ローカル変数に関連するスタックメモリのアドレスが返される"
-
[解決済み] error: 'if' の前に unqualified-id を期待した。
-
[解決済み] 既に.objで定義されている-二重包含はない
-
[解決済み】リンカーエラーです。"リンカ入力ファイルはリンクが行われていないため未使用"、そのファイル内の関数への未定義参照
-
[解決済み】ファイルから整数を読み込んで配列に格納する C++ 【クローズド
-
[解決済み】std::cin.getline( ) vs. std::cin
-
[解決済み] 警告:暗黙の定数変換でのオーバーフロー