Cod sursa(job #399367)
Utilizator | Data | 20 februarie 2010 13:25:06 | |
---|---|---|---|
Problema | Generare de permutari | Scor | 0 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.46 kb |
#include<iostream.h>
#include<conio.h>
#include<fstream.h>
int x[1000],n;
ofstream g("permutari.out");
ifstream f("permutari.in");
void afisare()
{int i;
for(i=1;i<=n;i++)
g<<x[i]<<" ";
g<<"\n";
}
int valid(int k)
{int i;
for(i=1;i<k;i++)
if(x[i]==x[k]) return 0;
return 1;
}
void back(int k)
{int i;
for(i=1;i<=n;i++)
{x[k]=i;
if(valid(k)==1) if(k==n) afisare();
else back(k+1);
}
}
void main()
{
clrscr();
f>>n;
back(1);
}