第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

在C ++中創(chuàng)建n個項目的所有可能的k個組合

在C ++中創(chuàng)建n個項目的所有可能的k個組合

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

3 回答

?
暮色呼如

TA貢獻1853條經(jīng)驗 獲得超9個贊

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


舉例來說,假設我們要從一組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) }

這是實現(xiàn)此想法的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 關(guān)注
  • 668 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號