QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#865884#9738. Make It DivisibleAngelOlanWA 1ms3712kbC++232.5kb2025-01-22 04:10:562025-01-22 04:11:03

Judging History

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

  • [2025-01-22 04:11:03]
  • 评测
  • 测评结果:WA
  • 用时:1ms
  • 内存:3712kb
  • [2025-01-22 04:10:56]
  • 提交

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;
}

Details

Tip: Click on the bar to expand more detailed information

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'