Altered Algorithm
This commit is contained in:
30
Algorithm/Enumerate/all_permutation_dfs.cpp
Normal file
30
Algorithm/Enumerate/all_permutation_dfs.cpp
Normal file
@@ -0,0 +1,30 @@
|
||||
#include <iostream>
|
||||
#include <vector>
|
||||
using namespace std;
|
||||
|
||||
template <class T>
|
||||
void dfs(vector<T>& _path, vector<bool>& _used, int n) {
|
||||
if(_path.size() == n){
|
||||
for(auto x : _path) cout << x << " ";
|
||||
cout << endl;
|
||||
return;
|
||||
}
|
||||
for(int i = 0; i < n; i++){
|
||||
if(!_used[i]) {
|
||||
_used[i] = true;
|
||||
_path.push_back(i + 1);
|
||||
dfs(_path, _used, n);
|
||||
_path.pop_back();
|
||||
_used[i] = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
int main(){
|
||||
int n;
|
||||
cin >> n;
|
||||
vector<int> path;
|
||||
vector<bool> used(n, false);
|
||||
dfs(path, used, n);
|
||||
return 0;
|
||||
}
|
Reference in New Issue
Block a user