名前空間
変種
操作

std::popcount

From cppreference.com
< cpp‎ | numeric
 
 
ユーティリティライブラリ
言語サポート
型のサポート (基本型、RTTI)
ライブラリ機能検査マクロ (C++20)
プログラムユーティリティ
可変引数関数
コルーチンサポート (C++20)
契約サポート (C++26)
三方比較
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

汎用ユーティリティ
関係演算子 (C++20で非推奨)
 
 
ヘッダ <bit> で定義
template< class T >
constexpr int popcount( T x ) noexcept;
(C++20以降)

x の値に含まれる 1 ビットの数を返します。

このオーバーロードは、T が符号なし整数型(すなわち、unsigned charunsigned shortunsigned intunsigned longunsigned long long、または拡張符号なし整数型)である場合にのみ、オーバーロード解決に参加します。

目次

[編集] パラメーター

x - 符号なし整数型の値

[編集] 戻り値

x の値に含まれる 1 ビットの数。

[編集] 備考

popcount という名前は "population count" の略です。

機能テストマクロ 規格 機能
__cpp_lib_bitops 201907L (C++20) ビット操作

[編集]

#include <bit>
#include <bitset>
#include <cstdint>
#include <iostream>
 
static_assert(std::popcount(0xFULL) == 4);
 
int main()
{
    for (const std::uint8_t x : {0, 0b00011101, 0b11111111})
        std::cout << "popcount( " << std::bitset<8>(x) << " ) = "
                  << std::popcount(x) << '\n';
}

出力

popcount( 00000000 ) = 0
popcount( 00011101 ) = 4
popcount( 11111111 ) = 8

[編集] 関連項目

最上位ビットから始まる連続した0ビットの数を数える
(関数テンプレート) [編集]
最上位ビットから始まる連続した1ビットの数を数える
(関数テンプレート) [編集]
最下位ビットから始まる連続した0ビットの数を数える
(関数テンプレート) [編集]
最下位ビットから始まる連続した1ビットの数を数える
(関数テンプレート) [編集]
数値が2の整数乗であるかチェックする
(関数テンプレート) [編集]
true に設定されているビットの数を返す
(std::bitset<N>のpublicメンバ関数) [編集]
全てのビット、いずれかのビット、またはいずれのビットも true に設定されているかをチェックする
(std::bitset<N> の公開メンバ関数) [編集]
English 日本語 中文(简体) 中文(繁體)