| Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
|---|---|---|---|---|---|---|---|---|---|
| 38868 | 23级徐泽厚 | 【S】T1 | C++ | 内存超限 | 52 | 3011 MS | 556936 KB | 1188 | 2025-11-10 19:16:10 |
#include <iostream> #include <vector> #include <algorithm> using namespace std; int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int n; cin >> n; vector<int> a(n); for (int i = 0; i < n; i++) { cin >> a[i]; } string result(n, '0'); for (int start = 0; start < n; start++) { vector<int> temp = a; bool valid = true; for (int i = 0; i < n; i++) { int pos = (start + i) % n; int next_pos = (pos + 1) % n; if (temp[pos] == 0 && temp[next_pos] == 0) { continue; } int min_val = min(temp[pos], temp[next_pos]); temp[pos] -= min_val; temp[next_pos] -= min_val; } // 检查是否所有元素都变为0 for (int i = 0; i < n; i++) { if (temp[i] != 0) { valid = false; break; } } if (valid) { result[start] = '1'; } } cout << result << endl; return 0; }