アフィリエイト広告を利用しています

広告

posted by fanblog

2017年11月17日

《その135》 「 1 」であるビットを数える


 「 1 」であるビットを数える

 整数内の「 1 」であるビットを数えるプログラムです。

 関数 int count_bits(Type x) が「 1 」であるビットを数えます。
@とAの2種類ありますが、両方とも同じ働きをします。


【 @の関数 】
 仮引数として受け取った整数 x を、右に 1ビットずつシフトしながら 整数 1 との論理積を調べます。
論理積が 0 になったら、x の「 1 」が無くなったことになるので、そこでカウント終了です。


【 Aの関数 】
 x &= x - 1; の操作で x の一番右にある「 1 」が消えることを利用しています。

x 00101100「 1 」が 3個
&) x-1 00101011
------------------
00101000「 1 」が 2個になった。

x が 0 になるまでの操作回数が「 1 」の個数ということになります。



 また、関数 char* bits_of(Type x) は "101・・・100"の形式の文字列を作ります。
両関数とも関数テンプレートにしてあるので、型が異なっていても受け取ってくれます。


#include <iostream>
using namespace std;

template <class Type>
char* bits_of(Type x) {
int n = numeric_limits<Type>::digits;
char* vec = new char[n + 1];

for (int i = 0; i < n; i++) {
if ((x >> i) & 1U) vec[n - i - 1] = '1';
else vec[n - i - 1] = '0';
}
vec[n] = '\0';
return vec;
}

template <class Type>
int count_bits(Type x) { // @
int bits = 0;
while (x) {
if (x & (Type)1) bits++;
x >>= 1;
}
return bits;
}

/*
template <class Type>
int count_bits(Type x) { // A
int bits = 0;
while (x) {
x &= x - 1;
bits++;
}
return bits;
}
*/


int main() {
cout << "unsigned long\n";
unsigned long a = 123456;
cout << bits_of(a) << " " << a << '\n';
cout << "1 であるビットの数 : " << count_bits(a) << "\n\n";

cout << "unsigned short\n";
unsigned short b = ~0;
cout << bits_of(b) << " " << b << '\n';
cout << "1 であるビットの数 : " << count_bits(b) << "\n\n";

cout << "unsigned int\n";
unsigned int c = 2863311530;
cout << bits_of(c) << " " << c << '\n';
cout << "1 であるビットの数 : " << count_bits(c) << '\n';
}

d02_0067.png


新版 明解C 入門編 (明解シリーズ)

新品価格
¥2,916から
(2017/11/10 13:13時点)

新版 明解C 中級編 (明解シリーズ)

新品価格
¥2,916から
(2017/11/10 13:14時点)





この記事へのコメント
コメントを書く

お名前:

メールアドレス:


ホームページアドレス:

コメント:

※ブログオーナーが承認したコメントのみ表示されます。

この記事へのトラックバックURL
https://fanblogs.jp/tb/6981240
※ブログオーナーが承認したトラックバックのみ表示されます。

この記事へのトラックバック

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


検索
<< 2018年08月 >>
      1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31  
プロフィール
こうすけさんの画像
こうすけ

 たまに、クリック お願いします m(_ _)m

 AA にほんブログ村 IT技術ブログ C/C++へ

こうすけ:メール kousuke_cpp@outlook.jp

【1】★★C++ 記事目次★★ ← 利用可能です。
・新版明解C++入門編 / 新版明解C++中級編
・その他 C++ 関連記事

【2】★★こうすけ@C#★★
・C# の初歩的な記事


×

この広告は30日以上新しい記事の更新がないブログに表示されております。