Cod sursa(job #1780390)

Utilizator elffikkVasile Ermicioi elffikk Data 16 octombrie 2016 08:56:42
Problema Problema Damelor Scor 60
Compilator cpp Status done
Runda Arhiva educationala Marime 0.86 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <algorithm>
#include <iterator>
using namespace std;

bool validate(vector<int> a) {
    for (int i = 0; i < a.size(); i++) {
        for (int j = i+1; j < a.size(); j++) {
            if (abs(i-j)==abs(a[i]-a[j])) {
                return false;
            }
        }
    }
    return true;
}

int main() {
    ifstream cin("damesah.in");
    ofstream cout("damesah.out");
    int n, m = 0;
    cin>>n;
    vector<int> a, v;
    for (int i = 0; i < n; i++) {
        a.push_back(i+1);
    }
    do {
        if (validate(a)) {
            m++;
            if (v.size()==0) {
                v = a;
            }
        }

    } while (next_permutation(a.begin(), a.end()));
    for (int i = 0; i < v.size(); i++) {
        cout<<v[i]<<" ";
    }
    cout<<"\n"<<m;
}