Pagini recente » Cod sursa (job #2840922) | Cod sursa (job #521721) | Cod sursa (job #1223350) | Cod sursa (job #144274) | Cod sursa (job #3185935)
#include <fstream>
#include <vector>
using namespace std;
ofstream fout("permutari.out");
int n;
vector<int> permutare;
bool isPresent(int val) { // O(n)
for(int x : permutare) {
if(x == val) {
return true;
}
}
return false;
}
void backtrack(int poz) {
if(poz == n + 1) {
/*for(int i = 0; i < permutare.size(); i++) {
fout << permutare[i] << " ";
}*/
for(int x : permutare) {
fout << x << " ";
}
fout << "\n";
return;
}
for(int i = 1; i <= n; i++) {
if(!isPresent(i)) {
permutare.push_back(i);
backtrack(poz + 1);
permutare.pop_back();
}
}
}
int main() {
ifstream fin("permutari.in");
fin >> n;
backtrack(1);
return 0;
}