Cod sursa(job #144670)
Utilizator | Savin Tiberiu devilkind | Data | 27 februarie 2008 20:50:05 |
---|---|---|---|
Problema | Generare de permutari | Scor | 100 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.42 kb |
#include <stdio.h>
long int n;
long int st[10],is[10];
void back(long int nivel)
{
long int i;
if (nivel==n+1)
{
for (i=1;i<=n;i++) printf("%ld ",st[i]);
printf("\n");
return;
}
for (i=1;i<=n;i++)
if (!is[i])
{
st[nivel]=i;
is[i]=1;
back(nivel+1);
is[i]=0;
}
}
int main()
{
freopen("permutari.in","r",stdin);
freopen("permutari.out","w",stdout);
scanf("%ld",&n);
back(1);
return 0;
}