#include #include using namespace std; using namespace atcoder; using ll = long long; using P = pair; #define rep(i,n) for(int (i)=0;(i)<(n);(i)++) #define rep2(i,m,n) for(int (i)=(m);(i)<(n);(i)++) #define rep2ll(i,m,n) for(ll (i)=(m);(i)<(n);(i)++) #define ALL(obj) (obj).begin(), (obj).end() #define rALL(obj) (obj).rbegin(), (obj).rend() const ll INF60 = 1LL<<60;//1152921504606846976 const int INF30 = 1<<30; using mint = modint998244353; using VL = vector; using VVL = vector; using VVVL = vector; using VM = vector; using VVM = vector; using VVVM = vector; using VD = vector; using VVD = vector; using VVVD = vector; templatebool chmax(T &a, const T &b) { if (abool chmin(T &a, const T &b) { if (b>n>>a>>b>>c; vector dp(n+1, 0); rep(i,n){ if(i+3<=n) chmax(dp[i+3], dp[i]+a); if(i+5<=n) chmax(dp[i+5], dp[i]+b); if(i+10<=n) chmax(dp[i+10], dp[i]+c); } cout<