Advertisement
JosepRivaille

P69348: D'un a ena (1)

May 17th, 2016
559
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.63 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3.  
  4.  
  5. void write_permutation(const vector<int> &v)
  6. {
  7.   cout << "(" << v[0];
  8.   for (int i = 1; i < v.size(); ++i) {
  9.     cout << "," << v[i];
  10.   }
  11.   cout << ")" << endl;
  12. }
  13.  
  14.  
  15. void backtrack(vector<int> &v, vector<int> used, int it)
  16. {
  17.   if (it == v.size()) write_permutation(v);
  18.   else {
  19.     for (int i = 0; i < v.size(); ++i) {
  20.       if (!used[i]) {
  21.     used[i] = true;
  22.     v[it] = i+1;
  23.     backtrack(v, used, it+1);
  24.     used[i] = false;
  25.       }
  26.     }
  27.   }
  28. }
  29.  
  30. int main()
  31. {
  32.   int n;
  33.   cin >> n;
  34.   vector<int> v(n);
  35.   vector<int> used(n);
  36.   backtrack(v, used, 0);
  37. }
  38.  
  39. //JosepRivaille
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement