Cod sursa(job #156049)
| Utilizator | Data | 12 martie 2008 12:22:47 | |
|---|---|---|---|
| Problema | Generare de permutari | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.51 kb |
#include <stdio.h>
#define NM 9
int n,x[NM];
void afis()
{ int i;
for (i=1;i<=n;i++) printf("%d ",x[i]);
printf("\n");
}
int valid(int k)
{ int i;
for (i=1;i<k;i++) if (x[i]==x[k]) return 0;
return 1;
}
void bkt(int k)
{ if (k>n)
{ afis();
return;
}
int i;
for (i=1;i<=n;i++)
{ x[k]=i;
if (valid(k)) bkt(k+1);
}
}
int main()
{ freopen("permutari.in","rt",stdin);
freopen("permutari.out","wt",stdout);
scanf("%d",&n);
bkt(1);
fcloseall();
return 0;
}