Enumerate Combination C(k, n) in a bitset

來源:互聯網
上載者:User

標籤:algorithm   c++   bitset   

Suppose n<=32, we can enumerate C(k, n), with bits representing absence or presence, in the following way:

#include <iostream>#include <vector>#include <bitset>using namespace std;bitset<32> getComb(const vector<int> &comb) {bitset<32> bitcombs;for (int i=0; i<comb.size(); ++i) bitcombs.set(comb[i], true);return bitcombs;}bool nextComb(vector<int> &comb, int n) {int k = comb.size(), i = k - 1;++comb[i];while (i>=1 && comb[i]>=n-k+1+i) ++comb[--i];if (comb[0] > n-k) return false; for (++i; i<k; ++i) comb[i] = comb[i-1] + 1;return true;}int main() {int n = 3, k = 2;vector<int> comb(k);for (int i=0; i<k; ++i) comb[i] = i;do {cout<<getComb(comb).to_ulong()<<endl;} while (nextComb(comb, n));return 0;}


The algorithms works like this when k=4, n=5:

01111->10111->11011->11101->11110

So, could you find the pattern? 



相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.