#include <bits/stdc++.h>
using namespace std;
#define nl "\n"
#define nf endl
#define ll long long
#define pb push_back
#define _ << ' ' <<
#define INF (ll)1e18
#define mod 998244353
#define maxn 110
#include "triples.h"
long long count_triples(std::vector<int> H) {
// subtask 4
ll n = H.size();
vector<array<ll, 3>> triples;
auto match = [&](ll i, ll j, ll k) {
// cout << "match" _ i _ j _ k << nf;
if (i >= j || j >= k) return;
array<ll, 3> a = {j - i, k - j, k - i};
array<ll, 3> b = {H[i], H[j], H[k]};
sort(a.begin(), a.end());
sort(b.begin(), b.end());
if (a == b) triples.pb({i, j, k});
};
for (ll k = 0; k < n; k++) {
ll i = k - H[k];
if (i < 0) continue;
ll hj = 2 * k - 2 * i - H[i] - H[k];
{
ll j = k - hj;
match(i, j, k);
}
{
ll j = i + hj;
match(i, j, k);
}
}
sort(triples.begin(), triples.end());
triples.resize(unique(triples.begin(), triples.end()) - triples.begin());
ll ans = triples.size();
return ans;
}
std::vector<int> construct_range(int M, int K) {
return {1, 1, 1};
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |