I am stuck in this dp + bitmasking question of spoj , can anyone help me with this?

Revision en1, by Chavanbhai1, 2024-12-29 13:13:58

question link : https://www.spoj.com/problems/HIST2/

include <bits/stdc++.h>

using namespace std;

define fastio() ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL)

int n; vector a; vector<vector<pair<int, int>>> dp;

pair<int, int> rec(int mask, int last) { int index = __builtin_popcount(mask);

if (index == n - 1) {
    for (int i = 0; i < n; ++i) {
        if (!((mask >> i) & 1))
            return {2 + abs(a[last] - a[i]) + a[i], 1};
    }
}

if (dp[mask][last] != make_pair(-1, -1))
    return dp[mask][last];

pair<int, int> ans = {-1e9, 0};
for (int i = 0; i < n; ++i) {
    if (!((mask >> i) & 1)) {
        int tempAns = 2 + abs(a[last] - a[i]);
        auto p = rec(mask | (1 << i), i);

        p.first += tempAns;
        if (ans.first < p.first) {
            ans = p;
        } else if (ans.first == p.first) {
            ans.second += p.second;
        }
    }
}

return dp[mask][last] = ans;

}

void solve() { dp.assign((1 << (n+1)), vector<pair<int, int>>(n + 1, {-1, -1})); auto ans = rec(0, n); cout << ans.first << " " << ans.second << "\n"; }

int32_t main() { fastio(); while (true) { cin >> n; if (n == 0) break;

a.resize(n + 1, 0);
    for (int i = 0; i < n; ++i) {
        cin >> a[i];
    }

    solve();
}
return 0;

} What can be the issue i am not able to find any flaw in this ?

History

 
 
 
 
Revisions
 
 
  Rev. Lang. By When Δ Comment
en1 English Chavanbhai1 2024-12-29 13:13:58 1650 Initial revision (published)