#include <iostream> #include <vector> #include <sstream> class Combination { public: Combination(int n=1, int k=1); bool next_combination(); int operator[](int i)const { return data[i]; } private: int n; int k; std::vector<int> data; }; Combination::Combination(int n, int k) : n(n), k(k) { if (n<=0 || k<=0) n = k = 1; if (n<k) n = k; for (int i=0; i<k; ++i) data.push_back(i); } bool Combination::next_combination() { if (n-k == data[0]) return false; int i = k-1; while (i>0 && data[i]==n-k+i) { --i; } ++data[i]; for (int j=i; j<k-1; ++j) data[j+1] = data[j] + 1; return true; } int main() { std::vector<std::string> mystrings; mystrings.push_back("string1"); mystrings.push_back("string2"); mystrings.push_back("string3"); mystrings.push_back("string4"); mystrings.push_back("string5"); mystrings.push_back("string6"); mystrings.push_back("string7"); mystrings.push_back("string8"); mystrings.push_back("string9"); mystrings.push_back("string10"); int n = mystrings.size(); // 10 int k = mystrings.size()/2; // 5 Combination mycombinator(n,k); int line = 1; do { std::cout << line++ << ") "; for (int i=0; i<k; ++i) std::cout << mystrings[mycombinator[i]] << " "; std::cout << "\n"; } while (mycombinator.next_combination()); }
Standard input is empty
1) string1 string2 string3 string4 string5 2) string1 string2 string3 string4 string6 3) string1 string2 string3 string4 string7 4) string1 string2 string3 string4 string8 5) string1 string2 string3 string4 string9 6) string1 string2 string3 string4 string10 7) string1 string2 string3 string5 string6 8) string1 string2 string3 string5 string7 9) string1 string2 string3 string5 string8 10) string1 string2 string3 string5 string9 11) string1 string2 string3 string5 string10 12) string1 string2 string3 string6 string7 13) string1 string2 string3 string6 string8 14) string1 string2 string3 string6 string9 15) string1 string2 string3 string6 string10 16) string1 string2 string3 string7 string8 17) string1 string2 string3 string7 string9 18) string1 string2 string3 string7 string10 19) string1 string2 string3 string8 string9 20) string1 string2 string3 string8 string10 21) string1 string2 string3 string9 string10 22) string1 string2 string4 string5 string6 23) string1 string2 string4 string5 string7 24) string1 string2 string4 string5 string8 25) string1 string2 string4 string5 string9 26) string1 string2 string4 string5 string10 27) string1 string2 string4 string6 string7 28) string1 string2 string4 string6 string8 29) string1 string2 string4 string6 string9 30) string1 string2 string4 string6 string10 31) string1 string2 string4 string7 string8 32) string1 string2 string4 string7 string9 33) string1 string2 string4 string7 string10 34) string1 string2 string4 string8 string9 35) string1 string2 string4 string8 string10 36) string1 string2 string4 string9 string10 37) string1 string2 string5 string6 string7 38) string1 string2 string5 string6 string8 39) string1 string2 string5 string6 string9 40) string1 string2 string5 string6 string10 41) string1 string2 string5 string7 string8 42) string1 string2 string5 string7 string9 43) string1 string2 string5 string7 string10 44) string1 string2 string5 string8 string9 45) string1 string2 string5 string8 string10 46) string1 string2 string5 string9 string10 47) string1 string2 string6 string7 string8 48) string1 string2 string6 string7 string9 49) string1 string2 string6 string7 string10 50) string1 string2 string6 string8 string9 51) string1 string2 string6 string8 string10 52) string1 string2 string6 string9 string10 53) string1 string2 string7 string8 string9 54) string1 string2 string7 string8 string10 55) string1 string2 string7 string9 string10 56) string1 string2 string8 string9 string10 57) string1 string3 string4 string5 string6 58) string1 string3 string4 string5 string7 59) string1 string3 string4 string5 string8 60) string1 string3 string4 string5 string9 61) string1 string3 string4 string5 string10 62) string1 string3 string4 string6 string7 63) string1 string3 string4 string6 string8 64) string1 string3 string4 string6 string9 65) string1 string3 string4 string6 string10 66) string1 string3 string4 string7 string8 67) string1 string3 string4 string7 string9 68) string1 string3 string4 string7 string10 69) string1 string3 string4 string8 string9 70) string1 string3 string4 string8 string10 71) string1 string3 string4 string9 string10 72) string1 string3 string5 string6 string7 73) string1 string3 string5 string6 string8 74) string1 string3 string5 string6 string9 75) string1 string3 string5 string6 string10 76) string1 string3 string5 string7 string8 77) string1 string3 string5 string7 string9 78) string1 string3 string5 string7 string10 79) string1 string3 string5 string8 string9 80) string1 string3 string5 string8 string10 81) string1 string3 string5 string9 string10 82) string1 string3 string6 string7 string8 83) string1 string3 string6 string7 string9 84) string1 string3 string6 string7 string10 85) string1 string3 string6 string8 string9 86) string1 string3 string6 string8 string10 87) string1 string3 string6 string9 string10 88) string1 string3 string7 string8 string9 89) string1 string3 string7 string8 string10 90) string1 string3 string7 string9 string10 91) string1 string3 string8 string9 string10 92) string1 string4 string5 string6 string7 93) string1 string4 string5 string6 string8 94) string1 string4 string5 string6 string9 95) string1 string4 string5 string6 string10 96) string1 string4 string5 string7 string8 97) string1 string4 string5 string7 string9 98) string1 string4 string5 string7 string10 99) string1 string4 string5 string8 string9 100) string1 string4 string5 string8 string10 101) string1 string4 string5 string9 string10 102) string1 string4 string6 string7 string8 103) string1 string4 string6 string7 string9 104) string1 string4 string6 string7 string10 105) string1 string4 string6 string8 string9 106) string1 string4 string6 string8 string10 107) string1 string4 string6 string9 string10 108) string1 string4 string7 string8 string9 109) string1 string4 string7 string8 string10 110) string1 string4 string7 string9 string10 111) string1 string4 string8 string9 string10 112) string1 string5 string6 string7 string8 113) string1 string5 string6 string7 string9 114) string1 string5 string6 string7 string10 115) string1 string5 string6 string8 string9 116) string1 string5 string6 string8 string10 117) string1 string5 string6 string9 string10 118) string1 string5 string7 string8 string9 119) string1 string5 string7 string8 string10 120) string1 string5 string7 string9 string10 121) string1 string5 string8 string9 string10 122) string1 string6 string7 string8 string9 123) string1 string6 string7 string8 string10 124) string1 string6 string7 string9 string10 125) string1 string6 string8 string9 string10 126) string1 string7 string8 string9 string10 127) string2 string3 string4 string5 string6 128) string2 string3 string4 string5 string7 129) string2 string3 string4 string5 string8 130) string2 string3 string4 string5 string9 131) string2 string3 string4 string5 string10 132) string2 string3 string4 string6 string7 133) string2 string3 string4 string6 string8 134) string2 string3 string4 string6 string9 135) string2 string3 string4 string6 string10 136) string2 string3 string4 string7 string8 137) string2 string3 string4 string7 string9 138) string2 string3 string4 string7 string10 139) string2 string3 string4 string8 string9 140) string2 string3 string4 string8 string10 141) string2 string3 string4 string9 string10 142) string2 string3 string5 string6 string7 143) string2 string3 string5 string6 string8 144) string2 string3 string5 string6 string9 145) string2 string3 string5 string6 string10 146) string2 string3 string5 string7 string8 147) string2 string3 string5 string7 string9 148) string2 string3 string5 string7 string10 149) string2 string3 string5 string8 string9 150) string2 string3 string5 string8 string10 151) string2 string3 string5 string9 string10 152) string2 string3 string6 string7 string8 153) string2 string3 string6 string7 string9 154) string2 string3 string6 string7 string10 155) string2 string3 string6 string8 string9 156) string2 string3 string6 string8 string10 157) string2 string3 string6 string9 string10 158) string2 string3 string7 string8 string9 159) string2 string3 string7 string8 string10 160) string2 string3 string7 string9 string10 161) string2 string3 string8 string9 string10 162) string2 string4 string5 string6 string7 163) string2 string4 string5 string6 string8 164) string2 string4 string5 string6 string9 165) string2 string4 string5 string6 string10 166) string2 string4 string5 string7 string8 167) string2 string4 string5 string7 string9 168) string2 string4 string5 string7 string10 169) string2 string4 string5 string8 string9 170) string2 string4 string5 string8 string10 171) string2 string4 string5 string9 string10 172) string2 string4 string6 string7 string8 173) string2 string4 string6 string7 string9 174) string2 string4 string6 string7 string10 175) string2 string4 string6 string8 string9 176) string2 string4 string6 string8 string10 177) string2 string4 string6 string9 string10 178) string2 string4 string7 string8 string9 179) string2 string4 string7 string8 string10 180) string2 string4 string7 string9 string10 181) string2 string4 string8 string9 string10 182) string2 string5 string6 string7 string8 183) string2 string5 string6 string7 string9 184) string2 string5 string6 string7 string10 185) string2 string5 string6 string8 string9 186) string2 string5 string6 string8 string10 187) string2 string5 string6 string9 string10 188) string2 string5 string7 string8 string9 189) string2 string5 string7 string8 string10 190) string2 string5 string7 string9 string10 191) string2 string5 string8 string9 string10 192) string2 string6 string7 string8 string9 193) string2 string6 string7 string8 string10 194) string2 string6 string7 string9 string10 195) string2 string6 string8 string9 string10 196) string2 string7 string8 string9 string10 197) string3 string4 string5 string6 string7 198) string3 string4 string5 string6 string8 199) string3 string4 string5 string6 string9 200) string3 string4 string5 string6 string10 201) string3 string4 string5 string7 string8 202) string3 string4 string5 string7 string9 203) string3 string4 string5 string7 string10 204) string3 string4 string5 string8 string9 205) string3 string4 string5 string8 string10 206) string3 string4 string5 string9 string10 207) string3 string4 string6 string7 string8 208) string3 string4 string6 string7 string9 209) string3 string4 string6 string7 string10 210) string3 string4 string6 string8 string9 211) string3 string4 string6 string8 string10 212) string3 string4 string6 string9 string10 213) string3 string4 string7 string8 string9 214) string3 string4 string7 string8 string10 215) string3 string4 string7 string9 string10 216) string3 string4 string8 string9 string10 217) string3 string5 string6 string7 string8 218) string3 string5 string6 string7 string9 219) string3 string5 string6 string7 string10 220) string3 string5 string6 string8 string9 221) string3 string5 string6 string8 string10 222) string3 string5 string6 string9 string10 223) string3 string5 string7 string8 string9 224) string3 string5 string7 string8 string10 225) string3 string5 string7 string9 string10 226) string3 string5 string8 string9 string10 227) string3 string6 string7 string8 string9 228) string3 string6 string7 string8 string10 229) string3 string6 string7 string9 string10 230) string3 string6 string8 string9 string10 231) string3 string7 string8 string9 string10 232) string4 string5 string6 string7 string8 233) string4 string5 string6 string7 string9 234) string4 string5 string6 string7 string10 235) string4 string5 string6 string8 string9 236) string4 string5 string6 string8 string10 237) string4 string5 string6 string9 string10 238) string4 string5 string7 string8 string9 239) string4 string5 string7 string8 string10 240) string4 string5 string7 string9 string10 241) string4 string5 string8 string9 string10 242) string4 string6 string7 string8 string9 243) string4 string6 string7 string8 string10 244) string4 string6 string7 string9 string10 245) string4 string6 string8 string9 string10 246) string4 string7 string8 string9 string10 247) string5 string6 string7 string8 string9 248) string5 string6 string7 string8 string10 249) string5 string6 string7 string9 string10 250) string5 string6 string8 string9 string10 251) string5 string7 string8 string9 string10 252) string6 string7 string8 string9 string10