結果
問題 | No.247 線形計画問題もどき |
ユーザー |
![]() |
提出日時 | 2020-03-06 01:58:01 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 29 ms / 2,000 ms |
コード長 | 1,293 bytes |
コンパイル時間 | 2,115 ms |
コンパイル使用メモリ | 195,000 KB |
最終ジャッジ日時 | 2025-01-09 04:37:24 |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 5 |
other | AC * 23 |
ソースコード
#include <bits/stdc++.h>using namespace std;using ll = long long;using VI = vector<int>;using VL = vector<ll>;using PII = std::pair<int, int>;using PLL = std::pair<ll, ll>;#define rep(i, n) for (int i = 0; i < (int)(n); i++)#define repr(i, n) for (int i = (int)(n)-1; i >= 0; i--)#define rep2(i, s, n) for (int i = (s); i < (int)(n); i++)#define allpt(v) (v).begin(), (v).end()#define allpt_r(v) (v).rbegin(), (v).rend()const int mod = 1e9 + 7;const string wsp = " ";const string tb = "\t";const string rt = "\n";template <typename T>void show1dvec(vector<T> v){int n = v.size() - 1;rep(i, n) cout << v[i] << wsp;cout << v[n] << rt;return;}template <typename T>void show2dvec(vector<vector<T>> v){int n = v.size();rep(i, n) show1dvec(v[i]);}int main(){#ifdef DEBUGcout << "DEBUG MODE" << endl;ifstream in("input.txt"); //for debugcin.rdbuf(in.rdbuf()); //for debug#endifint c, n, a;cin >> c >> n;VI dp(c + 1, 1e6);dp[0] = 0;rep(i, n){cin >> a;rep(j, c + 1){if (j + a <= c){dp[j + a] = min(dp[j + a], dp[j] + 1);}}}cout << ((dp[c] == 1e6) ? -1 : dp[c]) << rt;return 0;}