[解決済み] C言語で整数値からビット単位のデータを取得するには?
2022-08-02 03:48:08
質問
10進数のビットを抽出したい。
例えば、7は2進数の0111ですが、boolに格納されている全ビットの0 1 1 1を取り出したいのです。どのようにすればよいのでしょうか?
OK、ループは良い選択ではありません、このために何か他のことをすることができますか?
どのように解決するのですか?
nのk番目のビットが欲しい場合は、次のようにします。
(n & ( 1 << k )) >> k
ここでは、マスクを作成し、マスクをnに適用し、マスクされた値を右シフトして、必要なビットだけを取得しています。より完全に書くとこうなります。
int mask = 1 << k;
int masked_n = n & mask;
int thebit = masked_n >> k;
ビットマスキングについて詳しくは はこちら .
以下はプログラムです。
#include <stdio.h>
#include <stdlib.h>
int *get_bits(int n, int bitswanted){
int *bits = malloc(sizeof(int) * bitswanted);
int k;
for(k=0; k<bitswanted; k++){
int mask = 1 << k;
int masked_n = n & mask;
int thebit = masked_n >> k;
bits[k] = thebit;
}
return bits;
}
int main(){
int n=7;
int bitswanted = 5;
int *bits = get_bits(n, bitswanted);
printf("%d = ", n);
int i;
for(i=bitswanted-1; i>=0;i--){
printf("%d ", bits[i]);
}
printf("\n");
}
関連
-
C++の配列コピー
-
C: 1を求める! + 2! + 3! + ... + n! (ループ)
-
[解決済み] SQLiteのINSERT/per-secondのパフォーマンスを向上させる
-
[解決済み] 1ビットのセット、クリア、トグルはどのように行うのですか?
-
[解決済み] 32ビット整数のセットビットの数を数えるには?
-
[解決済み] CとC++でmain()は何を返すべきですか?
-
[解決済み] プログラム終了前にmallocの後にfreeをしないと本当に何が起こるのか?
-
[解決済み] Cの先頭の0を印刷する
-
[解決済み】ビットシフト(bit-shift)演算子とは、どのようなもので、どのように機能するのですか?
-
[解決済み】1回の乗算でビットを抽出する方法
最新
-
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 実装 サイバーパンク風ボタン
おすすめ
-
警告:代入がキャストなしで整数からポインタを作成する場合の修正方法に関する警告
-
VSCodeでCプログラムを書くとエラーになる:ソースファイル "stdio.h" を開くことができない
-
C 言語のポインタ配列のポインタ型、ポインタに値を割り当てるために配列名を使用、コンパイル時の警告:互換性のないポインタ型からの初期化
-
C - 添え字の値が配列でもポインタでもベクトルでもないエラー
-
警告: 'struct XXX' はパラメータリストの内部で宣言されています。
-
[解決済み] mallocで文字列を確保する
-
[解決済み] C - Setデータ構造を実装するには?
-
[解決済み] 配列の場合、なぜ a[5] == 5[a] になるのでしょうか?
-
[解決済み] C言語で関数をパラメータとして渡すにはどうすればよいですか?
-
[解決済み] printfにおけるdoubleの正しい書式指定子