Cod sursa(job #1016955)

Utilizator Alina_MariaMateescu Adina Lenuta Maria Alina_Maria Data 26 octombrie 2013 23:03:07
Problema Combinari Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.8 kb
#include <iostream>
#include <stdio.h>

using namespace std;

int n, k, sol[10], freq[10];

void afisareSolutie() {
    int i;
    for(i = 1; i < k; ++i)
        printf("%d ", sol[i]);
    printf("%d\n",sol[i]);
}

void backtrack(int lev) {
    if(lev > k) {
        afisareSolutie();
    } else {
        for(int i = 1; i <= n; ++i) {
            sol[lev] = i;
            //if(freq[i] == 0) { // pentru aranjamente
            if(freq[i] == 0 && sol[lev] > sol[lev - 1]) { // pentru combinari
                freq[i] = 1;
                backtrack(lev + 1);
                freq[i] = 0;
            }
        }
    }
}

int main() {
    freopen("combinari.in", "r", stdin);
    freopen("combinari.out", "w", stdout);
    scanf("%d %d", &n, &k);
    backtrack(1);
    return 0;
}