QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#865884 | #9738. Make It Divisible | AngelOlan | WA | 1ms | 3712kb | C++23 | 2.5kb | 2025-01-22 04:10:56 | 2025-01-22 04:11:03 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
// Pura Gente del Coach Moy
using i64 = long long;
struct SparseTable {
vector<vector<int>> jmp;
vector<int> b;
SparseTable(const vector<int>& b) : b(b) {
init();
}
inline int op(int i, int j) {
return b[i] <= b[j] ? i : j;
}
void init() {
{
jmp.emplace_back(vector<int>((int)b.size()));
for (int i = 0; i < (int)b.size(); ++i) {
jmp[0][i] = i;
}
}
for (int pw = 1, k = 1; pw * 2 <= (int)b.size(); pw *= 2, ++k) {
jmp.emplace_back((int)b.size() - pw * 2 + 1);
for (int j = 0; j < (int)jmp[k].size(); ++j) {
jmp[k][j] = op(jmp[k - 1][j], jmp[k - 1][j + pw]);
}
}
}
int query(int l, int r) { // [a, b)
int dep = 31 - __builtin_clz(r - l);
return op(jmp[dep][l], jmp[dep][r - (1 << dep)]);
}
};
int buildCartesianTree(int L, int R, vector<int>& l, vector<int>& r, SparseTable& st) {
if (L >= R) {
return -1;
}
int M = st.query(L, R);
// cout << L << ' ' << R << ' ' << M << '\n';
l[M] = buildCartesianTree(L, M, l, r, st);
r[M] = buildCartesianTree(M + 1, R, l, r, st);
if (l[M] == -1) {
l[M] = M;
}
if (r[M] == -1) {
r[M] = M;
}
return M;
}
void buildCartesianTree(int L, int R, vector<int>& l, vector<int>& r, vector<int>& b) {
SparseTable st(b);
buildCartesianTree(0, (int)b.size(), l, r, st);
}
bool check(int x, vector<int>& b, vector<int>& l, vector<int>& r) {
for (int i = 0; i < (int)b.size(); ++i) {
if (gcd(b[l[i]] + x, b[r[i]] + x) != b[i] + x) {
return false;
}
}
return true;
}
void solve() {
int n, k;
cin >> n >> k;
vector<int> b(n);
for (int& x : b) {
cin >> x;
}
int mn = *min_element(b.begin(), b.end()), mx = *max_element(b.begin(), b.end());
if (mn == mx) {
cout << k << ' ' << ((i64)k * (k + 1) >> 1) << '\n';
return;
}
int g = 0;
for (int i = 0; i + 1 < n; ++i) {
g = gcd(g, abs(b[i + 1] - b[i]));
}
vector<int> div;
for (int i = 1; i * i <= g; ++i) {
if (g % i == 0) {
div.push_back(i);
if (i * i != g) {
div.push_back(g / i);
}
}
}
vector<int> l(n), r(n);
buildCartesianTree(0, n, l, r, b);
int ans = 0;
i64 sum = 0;
for (int d : div) {
if (d > mn) {
int x = d - mn;
if (x <= k && check(x, b, l, r)) {
++ans;
sum += x;
}
}
}
cout << ans << ' ' << sum << '\n';
}
int main() {
cin.tie(0)->sync_with_stdio(0);
int t;
cin >> t;
while (t--) {
solve();
}
return 0;
}
详细
Test #1:
score: 100
Accepted
time: 1ms
memory: 3712kb
input:
3 5 10 7 79 1 7 1 2 1000000000 1 2 1 100 1000000000
output:
3 8 0 0 100 5050
result:
ok 3 lines
Test #2:
score: 0
Accepted
time: 0ms
memory: 3712kb
input:
4 201 1000000000 1 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5 2 5...
output:
0 0 0 0 0 0 0 0
result:
ok 4 lines
Test #3:
score: -100
Wrong Answer
time: 1ms
memory: 3584kb
input:
500 4 1000000000 8 14 24 18 4 1000000000 17 10 18 14 4 1000000000 6 17 19 19 4 1000000000 15 14 15 25 4 1000000000 16 16 5 25 4 1000000000 4 30 20 5 4 1000000000 11 4 23 9 4 1000000000 14 25 13 2 4 1000000000 18 18 1 15 4 1000000000 22 22 22 28 4 1000000000 15 17 17 10 4 1000000000 22 14 13 25 4 100...
output:
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 ...
result:
wrong answer 467th lines differ - expected: '1 8', found: '0 0'