Mai intai trebuie sa te autentifici.
Cod sursa(job #250412)
| Utilizator | Data | 30 ianuarie 2009 21:27:05 | |
|---|---|---|---|
| Problema | Generare de permutari | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.66 kb |
#include <stdio.h>
int n,sol[10];
void init(int k)
{
sol[k]=0;
}
int succesor(int k)
{
if (sol[k]<n)
{
sol[k]++;
return 1;
}
else
return 0;
}
int valid(int k)
{
int i,ev=1;
for (i=1; i<=k-1; i++)
if (sol[k]==sol[i])
ev=0;
return ev;
}
int solutie(int k)
{
return k==n+1;
}
void tipar()
{
for (int i=1; i<=n; i++)
printf("%d ",sol[i]);
printf("\n");
}
void back(int k)
{
if (solutie(k))
tipar();
else
{
init(k);
while(succesor(k))
if (valid(k))
back(k+1);
}
}
int main()
{
freopen("permutari.in","r",stdin);
freopen("permutari.out","w",stdout);
scanf("%d",&n);
back(1);
return 0;
}