C++ での符号なし整数回復除算アルゴリズムの実装
除算アルゴリズムを使用した符号なし整数の除算について説明します。除算アルゴリズムには、紙上で実装されるものもあれば、デジタル回路で実装されるものもあります。除算アルゴリズムには、低速除算アルゴリズムと高速除算アルゴリズムの 2 つがあります。低速除算アルゴリズムには、回復アルゴリズム、非実行回復アルゴリズム、SRT および非回復アルゴリズムが含まれます。
このチュートリアルでは、0 解法
ここでは、商を格納するレジスタQ、余りを格納するレジスタA、除数を格納するレジスタMを使用します。 A の初期値は 0 のままで、その値が復元されるため、メソッドは除算を再開します。
-
レジスタを値で初期化、
-
レジスタを値で初期化、 p>
Q = 配当、
- #A = 0、
- M = 除数、
- N = 被除数の桁数。
- #AQ を左にシフトすると、レジスタ A と Q を 1 つの単位として扱うことになります。 #A は M から減算され、A に格納されます。
- A の最上位ビットを確認します:
-
- 0 の場合は、最下位ビットを 1 に設定します。
- それ以外の場合は、最下位ビットを 0 に設定します。
#A の値を復元し、カウンタ N の値をデクリメントします。 - N = 0 の場合はループを終了し、それ以外の場合はステップ 2 に進みます。
- 商はレジスタ Q に格納されます。
- #フローチャート
上記のメソッドの C コード#include <iostream> using namespace std; int main(){ // initializing all the variables with Dividend = 9, Divisor = 2. int Q = 8,q=1,M=3; short N = 4; int A = Q; M <<= N; // loop for division by bit operation. for(int i=N-1; i>=0; i--) { A = (A << 1)- M; // checking MSB of A. if(A < 0) { q &= ~(1 << i); // set i-th bit to 0 A = A + M; } else { q |= 1 << i; // set i-th bit to 1 } } cout << "Quotient: "<< q; return 0; }
ログイン後にコピー出力
結論Quotient: 2
ログイン後にコピーこのチュートリアルでは、符号なし整数の回復除算アルゴリズムについて説明しました。フローチャートを使用し、ビット演算を適用して、この問題を解決する簡単な方法について説明しました。この問題を解決するための C プログラムについても説明しました。C、Java、Python などのプログラミング言語を使用して実装できます。このチュートリアルがお役に立てば幸いです。
-
以上がC++ での符号なし整数回復除算アルゴリズムの実装の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











この記事では、c関数のリターンタイプ、基本(int、float、charなど)、派生(配列、ポインター、構造体)、およびvoid型を含む詳細を示します。 コンパイラは、関数宣言とreturnステートメントを介して返品タイプを決定し、強制します

GULCは、最小限のオーバーヘッド、積極的なインライン、およびコンパイラの最適化を優先する高性能Cライブラリです。 高周波取引や組み込みシステムなどのパフォーマンスクリティカルなアプリケーションに最適な設計では、シンプルさ、モジュールが強調されています

この記事では、C関数宣言と定義、引数の合格(価値とポインターによる)、返品値、およびメモリリークやタイプの不一致などの一般的な落とし穴について説明します。 モジュール性とProviの宣言の重要性を強調しています

この記事では、文字列ケース変換のC関数について詳しく説明しています。 ctype.hのtoupper()とtolower()を使用し、文字列を介して繰り返し、ヌルターミネーターを処理することを説明しています。 ctype.hを忘れたり、文字列リテラルを変更するなどの一般的な落とし穴は

この記事では、C関数の戻り値ストレージを調べます。 通常、リターン値は通常、速度のためにレジスタに保存されます。値が大きいと、ポインターをメモリ(スタックまたはヒープ)に使用し、寿命に影響を与え、手動のメモリ管理が必要になります。直接acc

この記事では、形容詞の「個別」の多面的な使用法を分析し、その文法機能、一般的なフレーズ(例:「はっきりと異なる」とは異なる」、およびフォーマルと非公式の微妙なアプリケーションを調査します。

この記事では、C標準テンプレートライブラリ(STL)について説明し、そのコアコンポーネント(コンテナ、イテレーター、アルゴリズム、およびファンクター)に焦点を当てています。 これらが一般的なプログラミングを有効にし、コード効率を向上させ、読みやすさを改善する方法を詳述しています。

この記事では、cの効率的なSTLアルゴリズムの使用について詳しく説明しています。 データ構造の選択(ベクトル対リスト)、アルゴリズムの複雑さ分析(STD :: STD :: STD :: PARTIAL_SORTなど)、イテレーターの使用、および並列実行を強調しています。 のような一般的な落とし穴
