結果
| 問題 | 
                            No.2390 Udon Coupon (Hard)
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2023-07-21 23:04:44 | 
| 言語 | C++17  (gcc 13.3.0 + boost 1.87.0)  | 
                    
| 結果 | 
                             
                                WA
                                 
                             
                            
                         | 
                    
| 実行時間 | - | 
| コード長 | 541 bytes | 
| コンパイル時間 | 2,044 ms | 
| コンパイル使用メモリ | 196,080 KB | 
| 最終ジャッジ日時 | 2025-02-15 17:27:46 | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge1 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 28 WA * 19 | 
ソースコード
#include <bits/stdc++.h>
using namespace std;
int main() {
	long long N;
	cin >> N;
	vector<int> A(3), B(3);
	for (int i = 0; i < 3; i++){
		cin >> A[i] >> B[i];
	}
	auto f = [&](int x, int y) -> long long {
		int l = lcm(A[x], A[y]);
		vector<long long> dp(l + 1);
		for (int i = 0; i <= l; i++){
			for (int j = 0; j < 3; j++){
				if (i + A[j] <= l){
					dp[i + A[j]] = max(dp[i + A[j]], dp[i] + B[j]);
				}
			}
		}
		return dp[l] * (N / l) + dp[(N % l)];
	};
	long long ans = max({f(0, 1), f(0, 2), f(1, 2)});
	cout << ans << '\n';
}