結果
| 問題 |
No.527 ナップサック容量問題
|
| ユーザー |
vvataarne
|
| 提出日時 | 2017-06-09 22:36:43 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
AC
|
| 実行時間 | 75 ms / 2,000 ms |
| コード長 | 1,929 bytes |
| コンパイル時間 | 1,622 ms |
| コンパイル使用メモリ | 176,060 KB |
| 実行使用メモリ | 83,200 KB |
| 最終ジャッジ日時 | 2024-09-22 15:26:58 |
| 合計ジャッジ時間 | 4,130 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 37 |
ソースコード
// clang-format off
#include <bits/stdc++.h>
#define int long long
#define main signed main()
// #define main int main()
#define loop(i, a, n) for (int i = (a); i < (n); i++)
#define rep(i, n) loop(i, 0, n)
#define all(v) (v).begin(), (v).end()
#define rall(v) (v).rbegin(), (v).rend()
#define prec(n) fixed << setprecision(n)
#define stlice(from, to) substr(from, (to) - (from) + 1)
#define pb push_back
#define mp make_pair
#define mt make_tuple
#define fi first
#define se second
using namespace std;
using pii = pair<int, int>;
using vi = vector<int>;
using vd = vector<double>;
using vc = vector<char>;
using vb = vector<bool>;
using vs = vector<string>;
using vpii = vector<pii>;
using vvi = vector<vi>;
using vvb = vector<vb>;
using vvpii = vector<vpii>;
template<typename A> using fn = function<A>;
constexpr int INF = sizeof(int) == sizeof(long long) ? 1000000000000000000LL : 1000000000;
constexpr int MOD = 1000000007;
constexpr double PI = acos(-1);
template<typename A, typename B> bool cmin(A &a, const B &b) { return a > b ? (a = b, true) : false; }
template<typename A, typename B> bool cmax(A &a, const B &b) { return a < b ? (a = b, true) : false; }
constexpr bool odd(const int &n) { return n & 1; }
constexpr bool even(const int &n) { return !odd(n); }
void solve();
main { solve(); return 0; }
// clang-format on
void solve() {
int n;
cin >> n;
vi v(n), w(n);
rep(i, n) cin >> v[i] >> w[i];
int V;
cin >> V;
int W = 100000;
vvi dp(n + 1, vi(W + 1));
for (int i = n - 1; i >= 0; i--) {
rep(j, W + 1) {
if (j < w[i]) {
dp[i][j] = dp[i + 1][j];
} else {
dp[i][j] = max(dp[i + 1][j], dp[i + 1][j - w[i]] + v[i]);
}
}
}
int a = distance(dp[0].begin(), lower_bound(all(dp[0]), V));
auto b = upper_bound(all(dp[0]), V);
a += a == 0;
cout << a << '\n'
<< (b == dp[0].end() ? "inf" : to_string(distance(dp[0].begin(), b) - 1)) << endl;
}
vvataarne