Loading...
4/20/2025
#期待値 #動的計画法
https://atcoder.jp/contests/abc402/tasks/abc402_e
期待値DPの典型。「ある状態から始めたときに、ありうるスコアの期待値の最大値」を持てば良い。そのうえで、後ろから逆算して最も期待値が大きくなるような行動を取ったとしたときの期待値が計算できる。
この問題だと、既にACした問題の集合、残金を状態としてACした問題の集合、残金が円のときの期待値の最大値とすればよい。遷移は、
と書くことができる。計算量はとなる。提出
void solve() { int n, x; cin >> n >> x; vector<long double> s(n), p(n); vector<int> c(n); rep(i,n) cin>>s[i]>>c[i]>>p[i]; rep(i,n) p[i] = p[i]/100.0; vector<vector<long double>> dp(1<<n, vector<long double>(x+1, 0.0)); rep(j,x+1) { per(i,(1<<n)) { long double exp = 0; rep(k,n) { int ni = i | (1<<k); if(i==ni) continue; if(j<c[k]) continue; long double val = p[k]*(s[k]+dp[ni][j-c[k]]) + (1.0-p[k])*dp[i][j-c[k]]; chmax(exp, val); } dp[i][j] = exp; } } cout << fixed << setprecision(20) << dp[0][x] << ' '; } int main() { cin.tie(0); ios::sync_with_stdio(false); int t=1; //cin >> t; while(t--)solve(); }