QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#376794#3161. Another Coin Weighing Puzzleckiseki#WA 0ms3844kbC++201.5kb2024-04-04 16:44:242024-04-04 16:44:25

Judging History

你现在查看的是最新测评结果

  • [2024-04-04 16:44:25]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:3844kb
  • [2024-04-04 16:44:24]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;

#define all(x) begin(x), end(x)
#ifdef CKISEKI
#define safe cerr << __PRETTY_FUNCTION__ << " line " << __LINE__ << "\n";
#define debug(a...) debug_(#a, a)
#define orange(a...) orange_(#a, a)
void debug_(auto s, auto ...a) {
  cerr << "\e[1;32m(" << s << ") = (";
  int f = 0;
  (..., (cerr << (f++ ? ", " : "") << a));
  cerr << ")\e[0m\n";
}
#include <experimental/iterator>
void orange_(auto s, auto L, auto R) {
  cerr << "\e[1;33m[ " << s << " ] = [ ";
  using namespace experimental;
  copy(L, R, make_ostream_joiner(cerr, ", "));
  cerr << " ]\e[0m\n";
}
#else
#define safe ((void)0)
#define debug(...) safe
#define orange(...) safe
#endif

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


  int n, m;
  cin >> n >> m;
  vector<int> a(m);
  for (int i = 0; i < m; i++)
    cin >> a[i];


  using VI = vector<int>;
  set<VI> dp[11];

  {
    vector<int> s = {n};
    dp[0].insert(s);
  }

  for (int i = 0; i < m; i++) {
    for (auto v : dp[i]) {

      vector<set<VI>> cur(a[i] + 1);
      cur[0].insert({});
      for (size_t j = 0; j < v.size(); j++) {
        vector<set<VI>> nxt(a[i] + 1);
        for (int x = 0; x <= a[i]; x++)
          for (auto u : cur[x]) {
            for (int y = 0; x + y <= a[i] && y <= v[j]; y++) {
              u.push_back(y);
              // sort(all(u));
              nxt[x + y].insert(u);
            }
          }
        cur = nxt;
      }

      for (auto u : cur[a[i]])
        dp[i + 1].insert(u);
    }
  }

  debug(dp[m].size());

  return 0;
}

詳細信息

Test #1:

score: 0
Wrong Answer
time: 0ms
memory: 3844kb

input:

2 1

output:


result:

wrong answer 1st lines differ - expected: '9', found: ''