Pagini recente » Cod sursa (job #1430692) | Cod sursa (job #1806742) | Cod sursa (job #1427880) | Cod sursa (job #1156153) | Cod sursa (job #1098492)
#include<fstream>
using namespace std;
#define N 1000
ifstream f("permutari.in");
ofstream g("permutari.out");
bool isValid(int A[], int i, int n)
{
int frecv[N];
for(int j = 0; j <= n; j++)
{
frecv[j] = 0;
}
for(int j = 1; j <= i; j++)
{
if (frecv[A[j]])
{
return false;
}
frecv[A[j]]++;
}
return true;
}
void print(int A[], int n)
{
for(int i = 1; i <= n; i++)
{
g << A[i] << " ";
}
g << endl;
}
void perm(int A[], int i, int n)
{
for(int j = 1; j <= n; j++)
{
A[i] = j;
if (isValid(A, i, n))
{
if (i == n)
{
print(A, n);
}
else
{
perm(A, i + 1, n);
}
}
}
}
int main()
{
int A[N], n;
f >> n;
perm(A, 1, n);
}