亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在C ++中創建n個項目的所有可能的k個組合

在C ++中創建n個項目的所有可能的k個組合

慕的地6264312 2019-12-20 11:05:32
從1到有n個人n。我必須寫其產生的代碼,并打印的所有不同的組合k,從這些人n。請解釋用于此的算法。
查看完整描述

3 回答

?
暮色呼如

TA貢獻1853條經驗 獲得超9個贊

我假設您是在詢問組合意義上的組合(也就是說,元素的順序無關緊要,所以[1 2 3]與相同[2 1 3])。然后,這個想法非常簡單,如果您了解歸納/遞歸:要獲取所有K元素組合,請先從現有人員中選擇組合的初始元素,然后將該初始元素與所有可能的組合“連接” K-1人們從繼承最初元素的元素中產生出來。


舉例來說,假設我們要從一組5個人中抽取3個人的所有組合。然后,可以用2個人的所有可能組合來表示3個人的所有可能組合:


comb({ 1 2 3 4 5 }, 3) =

{ 1, comb({ 2 3 4 5 }, 2) } and

{ 2, comb({ 3 4 5 }, 2) } and

{ 3, comb({ 4 5 }, 2) }

這是實現此想法的C ++代碼:


#include <iostream>

#include <vector>


using namespace std;


vector<int> people;

vector<int> combination;


void pretty_print(const vector<int>& v) {

  static int count = 0;

  cout << "combination no " << (++count) << ": [ ";

  for (int i = 0; i < v.size(); ++i) { cout << v[i] << " "; }

  cout << "] " << endl;

}


void go(int offset, int k) {

  if (k == 0) {

    pretty_print(combination);

    return;

  }

  for (int i = offset; i <= people.size() - k; ++i) {

    combination.push_back(people[i]);

    go(i+1, k-1);

    combination.pop_back();

  }

}


int main() {

  int n = 5, k = 3;


  for (int i = 0; i < n; ++i) { people.push_back(i+1); }

  go(0, k);


  return 0;

}

這是輸出N = 5, K = 3:


combination no 1:  [ 1 2 3 ] 

combination no 2:  [ 1 2 4 ] 

combination no 3:  [ 1 2 5 ] 

combination no 4:  [ 1 3 4 ] 

combination no 5:  [ 1 3 5 ] 

combination no 6:  [ 1 4 5 ] 

combination no 7:  [ 2 3 4 ] 

combination no 8:  [ 2 3 5 ] 

combination no 9:  [ 2 4 5 ] 

combination no 10: [ 3 4 5 ] 


查看完整回答
反對 回復 2019-12-20
  • 3 回答
  • 0 關注
  • 661 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號