Cod sursa(job #3162473)

Utilizator CipriEuCruceanu Ciprian Constantin CipriEu Data 29 octombrie 2023 12:25:55
Problema Problema Damelor Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.83 kb
#include<bits/stdc++.h>
using namespace std;
ifstream fin("damesah.in");
ofstream fout("damesah.out");
int n, s[14], l[14], d1[28], d2[28], cnt=0;

void afis(){
    if(!cnt){
        for(int i=1; i<=n; i++) fout<<s[i]<<" ";
        fout<<"\n";
    }
    cnt++;
}

void bkt(int k){
    for(int i=1; i<=n; i++){
        //cout<<k<<" "<<i<<" "<<n-i+k<<" "<<k+i-1<<" ";
        if(!l[i] && !d1[n+(i-k)] && !d2[(k+i)-1]){
            //cout<<"true!\n";
            s[k] = i;
            l[i] = 1;
            d1[n+(i-k)] = 1;
            d2[(k+i)-1] = 1;
            if(k<n) bkt(k+1);
            else afis();
            d2[(k+i)-1] = 0;
            d1[n+(i-k)] = 0;
            l[i] = 0;
            s[k] = 0;
        }
        //else cout<<"false.\n";
    }
}

int main(){
    fin>>n;
    bkt(1);
    fout<<cnt;
}