Pagini recente » Arhiva de probleme | Cod sursa (job #2254518) | Cod sursa (job #650131) | Cod sursa (job #154944) | Cod sursa (job #2022381)
#include <bits/stdc++.h>
using namespace std;
int n, a[10];
bool valid(int k)
{
int i;
for(i=1;i<k;i++)
if(a[i]==a[k]) return false;
return true;
}
void afisare(int k)
{
int i;
for(i=1;i<=k;i++)
printf("%d ", a[i]);
printf("\n");
}
void backtrack(int k)
{
int i;
for(i=1;i<=n;i++)
{
a[k]=i;
if(valid(k)){
if(n==k)
afisare(k);
else
backtrack(k+1);
}
}
}
int main()
{
freopen ("permutari.in", "r", stdin);
freopen ("permutari.out", "w", stdout);
scanf("%d ", &n);
backtrack(1);
return 0;
}