QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#376794 | #3161. Another Coin Weighing Puzzle | ckiseki# | WA | 0ms | 3844kb | C++20 | 1.5kb | 2024-04-04 16:44:24 | 2024-04-04 16:44:25 |
Judging History
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: ''