[解決済み] ビットシフトと加算だけで乗除する方法は?
2023-01-20 13:27:20
質問
ビットシフトと加算だけで乗除算を行うにはどうしたらよいでしょうか?
どのように解決するのですか?
足し算とずらし算の掛け算は、片方の数字を2の累乗で分解して、このようにしたい。
21 * 5 = 10101_2 * 101_2 (Initial step)
= 10101_2 * (1 * 2^2 + 0 * 2^1 + 1 * 2^0)
= 10101_2 * 2^2 + 10101_2 * 2^0
= 10101_2 << 2 + 10101_2 << 0 (Decomposed)
= 10101_2 * 4 + 10101_2 * 1
= 10101_2 * 5
= 21 * 5 (Same as initial expression)
(
_2
はベース2を意味する)
見ての通り、乗算は加算とシフトに分解でき、また元に戻ることができます。これは、乗算がビットシフトや加算よりも時間がかかる理由でもあり、ビット数では O(n) ではなく O(n^2) となります。現実のコンピュータシステムは(理論上のコンピュータシステムとは対照的に)有限のビット数を持っているので、乗算は加算やシフトに比べ一定の倍数の時間がかかるのです。私の記憶が正しければ、最近のプロセッサは、適切にパイプライン化されていれば、プロセッサ内の ALU (演算ユニット) の使用率をいじることによって、乗算を加算と同じくらい速く実行することができます。
関連
-
[解決済み] SQLiteのINSERT/per-secondのパフォーマンスを向上させる
-
[解決済み] 1ビットのセット、クリア、トグルはどのように行うのですか?
-
[解決済み] なぜGCCはa*a*a*a*aを(a*a*a)*(a*a*a)に最適化しないのでしょうか?
-
[解決済み] const int*、const int * const、int const *の違いは何ですか?
-
[解決済み] 演算子 *, /, +, -, % を使わずに 3 で割る。
-
[解決済み] while ( !feof (file) ) 」は、なぜいつも間違っているのですか?
-
[解決済み] Intel CPU の _mm_popcnt_u64 で、32 ビットのループカウンターを 64 ビットに置き換えると、パフォーマンスが著しく低下します。
-
[解決済み】ビットシフト(bit-shift)演算子とは、どのようなもので、どのように機能するのですか?
-
[解決済み】1回の乗算でビットを抽出する方法
-
[解決済み】C言語でシフト演算子を使った掛け算・割り算は実は速い?
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
[C] Error [Error] 代入の左オペランドとして lvalue が必要です。
-
未定義の `__isoc99_sscanf' への参照
-
警告:符号付き整数式と符号なし整数式の比較 [-Wsign-compare]
-
[解決済み] MIPSのネストされたForループと配列の使用
-
[解決済み] C言語で%sを正しく使う - 超基本レベル
-
[解決済み] Linux Socket write() によるBad File Descriptor C
-
[解決済み] C言語の**はどういう意味ですか?
-
[解決済み] char s[]とchar *sの違いは何ですか?
-
[解決済み] C言語でファイルが存在するかどうかを確認する最も良い方法は何ですか?
-
[解決済み] フリーは、どのように無料化を知っているのですか?