From c52b36c6a37fdb1d1de146d3939cb42e2c691f44 Mon Sep 17 00:00:00 2001 From: omagdy7 Date: Sat, 5 Nov 2022 01:28:02 +0200 Subject: Solved 6 problem in filtrationContest and restructured the repo --- codeforces/recursionTest/recursionTest.cpp | 51 ++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 codeforces/recursionTest/recursionTest.cpp (limited to 'codeforces/recursionTest/recursionTest.cpp') diff --git a/codeforces/recursionTest/recursionTest.cpp b/codeforces/recursionTest/recursionTest.cpp new file mode 100644 index 0000000..91e9db8 --- /dev/null +++ b/codeforces/recursionTest/recursionTest.cpp @@ -0,0 +1,51 @@ +#include +#include + +using namespace std; + +string ans; + +bool solve(vector v,int idx, int target, int sum, string opts) { + if(idx == v.size() - 1) { + if(sum == target){ + ans = opts; + return true; + } + return false; + } + else { + int nxt = idx + 1; + bool plus = solve(v, nxt, target, sum + v[nxt],opts + "+"); + bool minus = solve(v, nxt, target, sum - v[nxt], opts + "-"); + bool mult = solve(v, nxt, target, sum * v[nxt], opts + "*"); + bool div = solve(v, nxt, target, sum / v[nxt], opts + "/"); + return plus || minus || mult || div; + } + +} + +int main() { + int n, target; + cin >> n >> target; + vector v(n); + string opts = ""; + for(int &x : v) { + cin >> x; + } + sort(v.begin(), v.end()); + do { + if(solve(v, 0, target, v[0], opts)) { + for(int i = 0; i < v.size(); i++) { + if (i == v.size() - 1) { + cout << v[i]; + } + else { + cout << v[i] << " " << ans[i] << " "; + } + } + cout << '\n'; + } + } while(next_permutation(v.begin(), v.end())); + + return 0; +} -- cgit v1.2.3