#include #include #include #include #include #include #include #include #include #include #include #include #include #include #define rep(i, a, b) for (int i = (a); i < (b); ++i) #define MOD 1000000007 #define int long long using ll = long long; using namespace std; const int INF = 1LL << 50; using P = pair; template bool chmin(T &a, T b) { if (a > b) { a = b; return true; } else { return false; } } template bool chmax(T &a, T b) { if (a < b) { a = b; return true; } else { return false; } } struct Setup { Setup() { cin.tie(0); ios::sync_with_stdio(false); cout << fixed << setprecision(20); } } SETUP; bool is_kado(int a, int b, int c) { if (a != c && b > a && b > c) { return true; } if (a != c && b < a && b < c) { return true; } return false; } // true : 先行の勝利 bool check(int n, int k) { bool ret; if (n <= k) { return false; } else { // ゲーム開始前、後攻は0を宣言しているものとする。 // 相手に負けさせるには、n-1を宣言したい。 // offset:k+1 // そのためにはn-1-offsetを宣言したい。そのためには...宣言したい数字が0以下になるまでループ。 // 0未満になったら先行が勝者。0ちょうどなら後攻が勝者。 ret = (n - 1) % (k + 1) == 0 ? true : false; } return ret; } signed main() { vector ls(3), cs(3); rep(i, 0, 3) { cin >> ls[i]; } rep(i, 0, 3) { cin >> cs[i]; } int ans = INF; rep(i, 0, 3) { int r = cs[i % 3], g = cs[(i + 1) % 3], b = cs[(i + 2) % 3]; int l1 = r * (ls[0] + ls[1]), l2 = g * (ls[1] + ls[2]), l3 = b * (ls[2] + ls[0]); chmin(ans, 2 * (l1 + l2 + l3)); } cout << ans << endl; }