Cod sursa(job #1249521)
| Utilizator | Data | 27 octombrie 2014 08:46:19 | |
|---|---|---|---|
| Problema | Generare de permutari | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.68 kb |
#include <cstdio>
using namespace std;
int v[9],n;
bool continuare(int k)
{
for (int i=1;i<=k-1;i++)
if (v[i]==v[k])
return 0;
return 1;
}
void genpermutari(int k)
{
if (k==n+1)
{
for (int i=1;i<=n;i++)
printf("%d ",v[i]);
printf("\n");
}
else
{
for (int i=1;i<=n;i++)
{
v[k]=i;
if (continuare(k))
{
genpermutari(k+1);
}
}
}
}
int main()
{
freopen("permutari.in","r",stdin);
freopen("permutari.out","w",stdout);
scanf("%d",&n);
genpermutari(1);
return 0;
}
