結果
問題 | No.286 Modulo Discount Store |
ユーザー |
![]() |
提出日時 | 2015-10-09 22:48:34 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 26 ms / 2,000 ms |
コード長 | 817 bytes |
コンパイル時間 | 573 ms |
コンパイル使用メモリ | 73,384 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-20 04:23:31 |
合計ジャッジ時間 | 1,817 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 40 |
ソースコード
#include<iostream>#include<cstdio>#include<algorithm>#include<cmath>#include<queue>#include<vector>#include<map>#include<list>#include<cctype>#include<climits>#include<bitset>using namespace std;#define int long longint N, M[15];signed main(){cin >> N;for (int i = 0; i < N; i++){cin >> M[i];}int dp[1 << 15];fill_n(dp, 1 << 15, LLONG_MAX / 2);dp[0] = 0;for (int i = 0; i <= N; i++){for (int j = (1 << N) - 1; j >= 0; j--){int sum = 0;for (int k = 0; k < N; k++){sum += M[k] * ((j >> k) & 1);}if (dp[j] == LLONG_MAX / 2) continue;for (int k = 0; k < N; k++){if (((j >> k) & 1)) continue;dp[j | (1 << k)] = min(dp[j | (1 << k)], dp[j] + max(0ll, M[k] - sum % 1000));}}}printf("%lld\n", dp[(1 << N) - 1]);return 0;}