Pagini recente » Cod sursa (job #1252865) | Cod sursa (job #1814395) | Cod sursa (job #489227) | Cod sursa (job #1450727) | Cod sursa (job #1019206)
#include <iostream>
#include <stdio.h>
using namespace std;
int n, v[10000], sol[10000];
void citireV(){
for(int i = 0; i < n; ++i)
scanf("%d ", &v[i]);
}
void backT(int k) {
if (k > n) {
return;
}
else {
// pt fiecare k (nivel, pozitie) vreau numere intre 1-n => merg pana la n doar ca pe niv k vreau numere mai mari decat pe niv k - 1
for(int i = sol[k - 1] + 1; i <= n; ++i) {
sol[k] = i;
// nu doar cand ajung la nivelul n (k == n) printez ci si pe parcurs, tot ce se afla in vect de solutie pana la nivelul la care sunt momentan
for (int j = 1; j <= k; ++j)
//printf("%d ", v[sol[j] - 1]);
printf("%d ", sol[j]);
printf("\n");
backT(k + 1);
}
}
}
int main()
{
freopen("submultimi.in", "r", stdin);
freopen("submultimi.out", "w", stdout);
scanf("%d", &n);
// citireV();
backT(1);
return 0;
}