Cod sursa(job #162192)
| Utilizator | Data | 19 martie 2008 17:50:52 | |
|---|---|---|---|
| Problema | Generare de permutari | Scor | 0 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.56 kb |
#include<stdio.h>
freopen("permutari.in","r",stdin);
freopen("pwrmutari.out","w",stdout);
int n, st[10];
int ok(int k);
int back(int k);
int write();
int main()
{ cin>>n;
back(0);
getch();
return 0;
}
int write()
{ int i;
for(i=0;i<n;i++)
cout<<st[i]<<" ";
cout<<'\n';
return 0;
}
int ok(int k)
{ int i;
for(i=0;i<k;i++)
if(st[i]==st[k])
return 0;
return 1;
}
int back(int k)
{ int i;
if(k==n-1)
write();
else
for(i=1;i<=n;i++)
{ st[k]=i;
if(ok(k))
back(k+1);
}
return 0;
}