[解決済み] マスクされた'ビットセットのインクリメント
2023-06-25 19:33:23
質問
現在、木の列挙器を書いている最中ですが、以下のような問題に出くわしました。
私はマスクされたビットセット、つまりセットビットがマスクのサブセットであるビットセットを見ています。
0000101
とマスク
1010101
. 私が達成したいことは、ビットセットをインクリメントすることですが、マスクされたビットに関してのみです。この例では、結果は次のようになります。
0010000
. もう少しわかりやすくするために、マスクされたビットだけを抽出する、つまり
0011
に増やし、それを
0100
に増やし、再びマスクビットに分配します。
0010000
.
ビットスキャンとプリフィックスマスクの組み合わせを使って手作業で操作を実装する以外に、これを行う効率的な方法があるでしょうか。
どのように解決するのですか?
マスク以外のビットを1で埋め、キャリー伝搬するようにすればよい。
// increments x on bits belonging to mask
x = ((x | ~mask) + 1) & mask;
関連
-
[解決済み】coutはstdのメンバではない
-
[解決済み】C++ 非推奨の文字列定数から「char*」への変換について
-
[解決済み】getline()が何らかの入力の後に使用されると動作しない 【重複あり
-
[解決済み】C++ - 解放されるポインタが割り当てられていないエラー
-
[解決済み】C++エラーです。"配列は中括弧で囲まれたイニシャライザーで初期化する必要がある"
-
[解決済み】C++ 式はポインタからオブジェクトへの型を持っている必要があります。
-
[解決済み】cc1plus:エラー:g++で認識されないコマンドラインオプション"-std=c++11"
-
[解決済み】1つ以上の多重定義されたシンボルが見つかる
-
[解決済み】Visual Studioのデバッガーエラー。プログラムを開始できません 指定されたファイルが見つかりません
-
[解決済み】変数やフィールドがvoid宣言されている
最新
-
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++でint型に無限大を設定する
-
[解決済み] エラーが発生する。ISO C++は型を持たない宣言を禁じています。
-
[解決済み】C++のGetlineの問題(オーバーロードされた関数 "getline "のインスタンスがない
-
[解決済み】C++ 式はポインタからオブジェクトへの型を持っている必要があります。
-
[解決済み] 非常に基本的なC++プログラムの問題 - バイナリ式への無効なオペランド
-
[解決済み] 数値定数の前にunqualified-idを付けて、数値を定義することを期待する。
-
[解決済み] to_string は std のメンバーではない、と g++ が言っている (mingw)
-
[解決済み】VC++の致命的なエラーLNK1168:書き込みのためにfilename.exeを開くことができません。
-
[解決済み】システムが指定されたファイルを見つけられませんでした。