[解決済み] C++ 整数の除算と剰余を得るための最良の方法
2022-10-09 13:23:44
質問
もし私がaをbで割りたいと思い、結果cと余りの両方に興味がある場合(例えば秒数があり、それを分と秒に分けたい)、どのようにするのがベストでしょうか?
それは
int c = (int)a / b;
int d = a % b;
または
int c = (int)a / b;
int d = a - b * c;
または
double tmp = a / b;
int c = (int)tmp;
int d = (int)(0.5+(tmp-c)*b);
または
両方を一度に得られる魔法の関数があるのでは?
どのように解決するのですか?
x86 では余りは除算の副産物なので、まともなコンパイラなら余りをそのまま使うことができるはずです(そして
div
を再度実行しない)。これはおそらく他のアーキテクチャでも行われていることでしょう。
命令です。
DIV
src注:符号なし除算。アキュムレータ(AX)を"src"で割ります。除算器がバイト値の場合 がバイトの場合、結果はALに格納されます。 に、余りはAH . 被除数 がワード値の場合、DX:AXは "src"で割られ、結果は をAXに格納します。 に格納され、余りはDX .
int c = (int)a / b;
int d = a % b; /* Likely uses the result of the division. */
関連
-
[解決済み】C++ 式はポインタからオブジェクトへの型を持っている必要があります。
-
[解決済み】c++でstd::vectorを返すための効率的な方法
-
[解決済み】システムが指定されたファイルを見つけられませんでした。
-
[解決済み】'std::cout'への未定義の参照
-
[解決済み】c++で.txtファイルから2次元の配列に読み込む
-
[解決済み] Rubyの除算はなぜ10進数ではなく整数を返すのですか?
-
[解決済み] 1サイクルあたり4FLOPの理論上の最大値を達成するにはどうすればよいですか?
-
[解決済み] Intel CPU の _mm_popcnt_u64 で、32 ビットのループカウンターを 64 ビットに置き換えると、パフォーマンスが著しく低下します。
-
[解決済み】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 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】致命的なエラー LNK1169: ゲームプログラミングで1つ以上の多重定義されたシンボルが発見された
-
[解決済み】テンプレートの引数1が無効です(Code::Blocks Win Vista) - テンプレートは使いません。
-
[解決済み】浮動小数点例外エラーが発生する: 8
-
[解決済み】Visual C++で "Debug Assertion failed "の原因となる行を見つける。
-
[解決済み] 式はクラス型を持つ必要があります。
-
[解決済み] 非静的データメンバの無効な使用
-
[解決済み】CMakeエラー at CMakeLists.txt:30 (project)。CMAKE_C_COMPILER が見つかりませんでした。
-
[解決済み】クラスのコンストラクタへの未定義参照、.cppファイルの修正も含む
-
[解決済み】C++ - ステートメントがオーバーロードされた関数のアドレスを解決できない。
-
[解決済み] 変数サイズのオブジェクトが初期化されないことがある c++