0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

[競プロ]p進数でのbit全探索

Last updated at Posted at 2021-05-24

2進数での通常のbit全探索

n(割と小さめ)個のものがあり、それぞれに二つの状態があるとき、全探索をする際はいわゆる「bit全探索」を行うと思います。これは2n通りを全探索しています。競プロでは「使うor使わない」や「ON/OFF」などの文脈において全探索する際に便利です。
以下がコード例です。

for(int bit=0; bit<(1<<n); bit++){
    // 右からi番目にビットが立っているかどうか(2進数で表したときに1であるか)
    for(int i=0; i<n; i++){
        if(bit & (1<<i)){
            // i番目が1である
        }else{
            // i番目が0である
        }
    }
}

p進数でのbit全探索

2進数の時と同様に、n(割と小さめ)個のものがあり、それぞれにp個の状態がある時、pn通りを全探索したい時があると思います。
例えば次の問題ではp=4(Aに使う・Bに使う・Cに使う・使わない)での全探索を行いたいです。

p進数を用いることで、すべての状態を探索すること
ができます。
以下がp進数でのbit全探索のコード例です。

int p=4;
for(int bit=0; bit<pow(p, n); bit++){
    int tmp=bit;
    vector<int> state(n);
    // 右からi(0~n-1)番目の状態(0~k-1)
    for(int i=0; i<n; i++){
        state[n-1-i]=tmp%p;
        tmp/=p;
    }
    // 各状態をチェック
    for(int i=0; i<n; i++){
        cout << state[i] << " ";
    }
    cout << endl;
}

これの出力は次のようになります

0 0 0 0 0  
0 0 0 0 1  
0 0 0 0 2  
0 0 0 0 3  
0 0 0 1 0  
0 0 0 1 1  
0 0 0 1 2  
0 0 0 1 3  
0 0 0 2 0  
0 0 0 2 1
.
.
.
3 3 3 2 0
3 3 3 2 1
3 3 3 2 2
3 3 3 2 3
3 3 3 3 0
3 3 3 3 1 
3 3 3 3 2
3 3 3 3 3

n個それぞれ0~3の全ての状態について探索できました。

0
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?