-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcombinaison.cpp
79 lines (67 loc) · 1.32 KB
/
combinaison.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#include <vector>
#include <iostream>
typedef std::vector<int> NUplet;
typedef std::vector<NUplet> Lists;
/*
void n_for(int i, const Lists& lists, Lists& result, NUplet& n_uplet)
{
if (i!=lists.size())
{
for(auto & x : lists[i])
{
n_uplet[i] = x;
n_for(i+1,lists,result,n_uplet);
}
}
else
result.push_back(n_uplet);
}
Lists combinaison(const Lists& lists)
{
Lists result;
NUplet n_uplet(lists.size(),0);
n_for(0,lists,result,n_uplet);
return result;
}
*/
template<class Lists>
class NFor
{
public:
NFor(const Lists& lists_):lists(lists_),n_uplet(lists.size(),0){iterate(0);}
const Lists& solution() { return result; }
private:
void iterate(int i)
{
if (i!=lists.size())
{
for(auto & x : lists[i])
{
n_uplet[i] = x;
iterate(i+1);
}
}
else
result.push_back(n_uplet);
}
const Lists& lists;
Lists result;
typename Lists::value_type n_uplet;
};
Lists combinaison(const Lists& lists)
{
return NFor<Lists>(lists).solution();
}
int main()
{
Lists w {{1,2},{3,4,5},{6,7,8,9}};
Lists result = combinaison(w);
std::cout << std::endl << std::endl;
for(auto& x : result)
{
for(auto& y : x)
std::cout << y << ",";
std::cout << std::endl;
}
std::cout << std::endl;
}