Cod sursa(job #1528126)

Utilizator abccnuCamelia Zalum abccnu Data 19 noiembrie 2015 08:21:38
Problema Problema Damelor Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.88 kb
#include <iostream>
#include <math.h>
#include<fstream>
using namespace std;


int x[13];
int solutie[13], nrSolutii, n;



void afisare() {
    for (int i = 1; i <= n; ++i) {
        solutie[i] = x[i];
    }
}

bool valid(int k){
    for (int i = 1; i < k; ++i)        if ((x[k] == x[i]) || (k - i == fabs(x[k] - x[i]))){
            return false;
    }
    return true;
}

void back(int k){

    if (k==n+1) {
                  ++nrSolutii;
                  if (nrSolutii==1) afisare();

                }
    else
     for (int i=1; i<=n; i++)
        {
            x[k]=i;
            if (valid(k)) back(k+1);
        }
}

int main() {
    ofstream o("damesah.out");
    ifstream f("damesah.in");

    f >> n;
    back(1);
    for (int i = 1; i <= n; ++i){
        o << solutie[i] << " ";
    }
    o << '\n';
    o << nrSolutii;
    return 0;
}