Cod sursa(job #1560780)
| Utilizator | Data | 3 ianuarie 2016 12:18:05 | |
|---|---|---|---|
| Problema | Generare de permutari | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.56 kb |
# include <cstdio>
# define N 10
using namespace std;
int n,k;
bool sel[N];
int sol[N];
void afiseaza(int k)
{
for(int i=1; i<=k; ++i)
printf("%d ", sol[i]);
printf("\n");
}
void back(int k)
{
if(k==n) afiseaza(k);
else for(int i=1; i<=n; ++i)
if(!sel[i])
{
sel[i]=true; sol[++k]=i;
back(k);
sel[i]=false; k--;
}
}
int main()
{
freopen("permutari.in", "r", stdin);
freopen("permutari.out", "w", stdout);
scanf("%d\n", &n);
back(0);
}
