Submission #1358057

#TimeUsernameProblemLanguageResultExecution timeMemory
1358057avighnaCookies (JOI23_cookies)C++20
6 / 100
0 ms348 KiB
#include <bits/stdc++.h>

using namespace std;

const int inf = 1e9;

int main() {
  cin.tie(nullptr)->sync_with_stdio(false);

  int n, m;
  cin >> n;
  vector<int> a(n);
  for (int &i : a) { cin >> i; }
  cin >> m;
  vector<int> b(m);
  for (int &i : b) { cin >> i; }

  vector<int> dp(n + 1, inf);
  dp[0] = 0;
  for (int i = 1; i <= n; ++i) {
    for (int &s : b) {
      if (i - s >= 0) {
        dp[i] = min(dp[i], dp[i - s] + 1);
      }
    }
  }

  if (dp[n] == inf) {
    cout << "-1\n";
    return 0;
  }

  vector<int> ans;
  int x = n;
  while (x) {
    for (int &s : b) {
      if (x - s >= 0 && dp[x] == dp[x - s] + 1) {
        ans.push_back(s);
        x -= s;
        break;
      }
    }
  }

  cout << dp[n] << '\n';
  int p = 1;
  for (int &i : ans) {
    cout << i << ' ';
    for (int j = 0; j < i; ++j) {
      cout << p++ << ' ';
    }
    cout << '\n';
  }
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...