QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#108820 | #6192. Interval Problem | maspy | AC ✓ | 380ms | 247944kb | C++23 | 18.5kb | 2023-05-26 18:29:15 | 2023-05-26 18:29:19 |
Judging History
answer
#line 1 "library/my_template.hpp"
#if defined(LOCAL)
#include <my_template_compiled.hpp>
#else
#pragma GCC optimize("Ofast")
#pragma GCC optimize("unroll-loops")
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
using u32 = unsigned int;
using u64 = unsigned long long;
using i128 = __int128;
template <class T>
constexpr T infty = 0;
template <>
constexpr int infty<int> = 1'000'000'000;
template <>
constexpr ll infty<ll> = ll(infty<int>) * infty<int> * 2;
template <>
constexpr u32 infty<u32> = infty<int>;
template <>
constexpr u64 infty<u64> = infty<ll>;
template <>
constexpr i128 infty<i128> = i128(infty<ll>) * infty<ll>;
template <>
constexpr double infty<double> = infty<ll>;
template <>
constexpr long double infty<long double> = infty<ll>;
using pi = pair<ll, ll>;
using vi = vector<ll>;
template <class T>
using vc = vector<T>;
template <class T>
using vvc = vector<vc<T>>;
template <class T>
using vvvc = vector<vvc<T>>;
template <class T>
using vvvvc = vector<vvvc<T>>;
template <class T>
using vvvvvc = vector<vvvvc<T>>;
template <class T>
using pq = priority_queue<T>;
template <class T>
using pqg = priority_queue<T, vector<T>, greater<T>>;
#define vv(type, name, h, ...) \
vector<vector<type>> name(h, vector<type>(__VA_ARGS__))
#define vvv(type, name, h, w, ...) \
vector<vector<vector<type>>> name( \
h, vector<vector<type>>(w, vector<type>(__VA_ARGS__)))
#define vvvv(type, name, a, b, c, ...) \
vector<vector<vector<vector<type>>>> name( \
a, vector<vector<vector<type>>>( \
b, vector<vector<type>>(c, vector<type>(__VA_ARGS__))))
// https://trap.jp/post/1224/
#define FOR1(a) for (ll _ = 0; _ < ll(a); ++_)
#define FOR2(i, a) for (ll i = 0; i < ll(a); ++i)
#define FOR3(i, a, b) for (ll i = a; i < ll(b); ++i)
#define FOR4(i, a, b, c) for (ll i = a; i < ll(b); i += (c))
#define FOR1_R(a) for (ll i = (a)-1; i >= ll(0); --i)
#define FOR2_R(i, a) for (ll i = (a)-1; i >= ll(0); --i)
#define FOR3_R(i, a, b) for (ll i = (b)-1; i >= ll(a); --i)
#define overload4(a, b, c, d, e, ...) e
#define overload3(a, b, c, d, ...) d
#define FOR(...) overload4(__VA_ARGS__, FOR4, FOR3, FOR2, FOR1)(__VA_ARGS__)
#define FOR_R(...) overload3(__VA_ARGS__, FOR3_R, FOR2_R, FOR1_R)(__VA_ARGS__)
#define FOR_subset(t, s) \
for (ll t = (s); t >= 0; t = (t == 0 ? -1 : (t - 1) & (s)))
#define all(x) x.begin(), x.end()
#define len(x) ll(x.size())
#define elif else if
#define eb emplace_back
#define mp make_pair
#define mt make_tuple
#define fi first
#define se second
#define stoi stoll
int popcnt(int x) { return __builtin_popcount(x); }
int popcnt(u32 x) { return __builtin_popcount(x); }
int popcnt(ll x) { return __builtin_popcountll(x); }
int popcnt(u64 x) { return __builtin_popcountll(x); }
// (0, 1, 2, 3, 4) -> (-1, 0, 1, 1, 2)
int topbit(int x) { return (x == 0 ? -1 : 31 - __builtin_clz(x)); }
int topbit(u32 x) { return (x == 0 ? -1 : 31 - __builtin_clz(x)); }
int topbit(ll x) { return (x == 0 ? -1 : 63 - __builtin_clzll(x)); }
int topbit(u64 x) { return (x == 0 ? -1 : 63 - __builtin_clzll(x)); }
// (0, 1, 2, 3, 4) -> (-1, 0, 1, 0, 2)
int lowbit(int x) { return (x == 0 ? -1 : __builtin_ctz(x)); }
int lowbit(u32 x) { return (x == 0 ? -1 : __builtin_ctz(x)); }
int lowbit(ll x) { return (x == 0 ? -1 : __builtin_ctzll(x)); }
int lowbit(u64 x) { return (x == 0 ? -1 : __builtin_ctzll(x)); }
template <typename T, typename U>
T ceil(T x, U y) {
return (x > 0 ? (x + y - 1) / y : x / y);
}
template <typename T, typename U>
T floor(T x, U y) {
return (x > 0 ? x / y : (x - y + 1) / y);
}
template <typename T, typename U>
pair<T, T> divmod(T x, U y) {
T q = floor(x, y);
return {q, x - q * y};
}
template <typename T, typename U>
T SUM(const vector<U> &A) {
T sum = 0;
for (auto &&a: A) sum += a;
return sum;
}
#define MIN(v) *min_element(all(v))
#define MAX(v) *max_element(all(v))
#define LB(c, x) distance((c).begin(), lower_bound(all(c), (x)))
#define UB(c, x) distance((c).begin(), upper_bound(all(c), (x)))
#define UNIQUE(x) \
sort(all(x)), x.erase(unique(all(x)), x.end()), x.shrink_to_fit()
template <typename T>
T POP(deque<T> &que) {
T a = que.front();
que.pop_front();
return a;
}
template <typename T>
T POP(pq<T> &que) {
T a = que.top();
que.pop();
return a;
}
template <typename T>
T POP(pqg<T> &que) {
assert(!que.empty());
T a = que.top();
que.pop();
return a;
}
template <typename T>
T POP(vc<T> &que) {
assert(!que.empty());
T a = que.back();
que.pop_back();
return a;
}
template <typename F>
ll binary_search(F check, ll ok, ll ng, bool check_ok = true) {
if (check_ok) assert(check(ok));
while (abs(ok - ng) > 1) {
auto x = (ng + ok) / 2;
tie(ok, ng) = (check(x) ? mp(x, ng) : mp(ok, x));
}
return ok;
}
template <typename F>
double binary_search_real(F check, double ok, double ng, int iter = 100) {
FOR(iter) {
double x = (ok + ng) / 2;
tie(ok, ng) = (check(x) ? mp(x, ng) : mp(ok, x));
}
return (ok + ng) / 2;
}
template <class T, class S>
inline bool chmax(T &a, const S &b) {
return (a < b ? a = b, 1 : 0);
}
template <class T, class S>
inline bool chmin(T &a, const S &b) {
return (a > b ? a = b, 1 : 0);
}
// ? は -1
vc<int> s_to_vi(const string &S, char first_char) {
vc<int> A(S.size());
FOR(i, S.size()) { A[i] = (S[i] != '?' ? S[i] - first_char : -1); }
return A;
}
template <typename T, typename U>
vector<T> cumsum(vector<U> &A, int off = 1) {
int N = A.size();
vector<T> B(N + 1);
FOR(i, N) { B[i + 1] = B[i] + A[i]; }
if (off == 0) B.erase(B.begin());
return B;
}
// stable sort
template <typename T>
vector<int> argsort(const vector<T> &A) {
vector<int> ids(len(A));
iota(all(ids), 0);
sort(all(ids),
[&](int i, int j) { return (A[i] == A[j] ? i < j : A[i] < A[j]); });
return ids;
}
// A[I[0]], A[I[1]], ...
template <typename T>
vc<T> rearrange(const vc<T> &A, const vc<int> &I) {
vc<T> B(len(I));
FOR(i, len(I)) B[i] = A[I[i]];
return B;
}
#endif
#line 1 "library/other/io.hpp"
// based on yosupo's fastio
#include <unistd.h>
namespace fastio {
#define FASTIO
// クラスが read(), print() を持っているかを判定するメタ関数
struct has_write_impl {
template <class T>
static auto check(T &&x) -> decltype(x.write(), std::true_type{});
template <class T>
static auto check(...) -> std::false_type;
};
template <class T>
class has_write : public decltype(has_write_impl::check<T>(std::declval<T>())) {
};
struct has_read_impl {
template <class T>
static auto check(T &&x) -> decltype(x.read(), std::true_type{});
template <class T>
static auto check(...) -> std::false_type;
};
template <class T>
class has_read : public decltype(has_read_impl::check<T>(std::declval<T>())) {};
struct Scanner {
FILE *fp;
char line[(1 << 15) + 1];
size_t st = 0, ed = 0;
void reread() {
memmove(line, line + st, ed - st);
ed -= st;
st = 0;
ed += fread(line + ed, 1, (1 << 15) - ed, fp);
line[ed] = '\0';
}
bool succ() {
while (true) {
if (st == ed) {
reread();
if (st == ed) return false;
}
while (st != ed && isspace(line[st])) st++;
if (st != ed) break;
}
if (ed - st <= 50) {
bool sep = false;
for (size_t i = st; i < ed; i++) {
if (isspace(line[i])) {
sep = true;
break;
}
}
if (!sep) reread();
}
return true;
}
template <class T, enable_if_t<is_same<T, string>::value, int> = 0>
bool read_single(T &ref) {
if (!succ()) return false;
while (true) {
size_t sz = 0;
while (st + sz < ed && !isspace(line[st + sz])) sz++;
ref.append(line + st, sz);
st += sz;
if (!sz || st != ed) break;
reread();
}
return true;
}
template <class T, enable_if_t<is_integral<T>::value, int> = 0>
bool read_single(T &ref) {
if (!succ()) return false;
bool neg = false;
if (line[st] == '-') {
neg = true;
st++;
}
ref = T(0);
while (isdigit(line[st])) { ref = 10 * ref + (line[st++] & 0xf); }
if (neg) ref = -ref;
return true;
}
template <typename T,
typename enable_if<has_read<T>::value>::type * = nullptr>
inline bool read_single(T &x) {
x.read();
return true;
}
bool read_single(double &ref) {
string s;
if (!read_single(s)) return false;
ref = std::stod(s);
return true;
}
bool read_single(char &ref) {
string s;
if (!read_single(s) || s.size() != 1) return false;
ref = s[0];
return true;
}
template <class T>
bool read_single(vector<T> &ref) {
for (auto &d: ref) {
if (!read_single(d)) return false;
}
return true;
}
template <class T, class U>
bool read_single(pair<T, U> &p) {
return (read_single(p.first) && read_single(p.second));
}
template <size_t N = 0, typename T>
void read_single_tuple(T &t) {
if constexpr (N < std::tuple_size<T>::value) {
auto &x = std::get<N>(t);
read_single(x);
read_single_tuple<N + 1>(t);
}
}
template <class... T>
bool read_single(tuple<T...> &tpl) {
read_single_tuple(tpl);
return true;
}
void read() {}
template <class H, class... T>
void read(H &h, T &... t) {
bool f = read_single(h);
assert(f);
read(t...);
}
Scanner(FILE *fp) : fp(fp) {}
};
struct Printer {
Printer(FILE *_fp) : fp(_fp) {}
~Printer() { flush(); }
static constexpr size_t SIZE = 1 << 15;
FILE *fp;
char line[SIZE], small[50];
size_t pos = 0;
void flush() {
fwrite(line, 1, pos, fp);
pos = 0;
}
void write(const char val) {
if (pos == SIZE) flush();
line[pos++] = val;
}
template <class T, enable_if_t<is_integral<T>::value, int> = 0>
void write(T val) {
if (pos > (1 << 15) - 50) flush();
if (val == 0) {
write('0');
return;
}
if (val < 0) {
write('-');
val = -val; // todo min
}
size_t len = 0;
while (val) {
small[len++] = char(0x30 | (val % 10));
val /= 10;
}
for (size_t i = 0; i < len; i++) { line[pos + i] = small[len - 1 - i]; }
pos += len;
}
void write(const string s) {
for (char c: s) write(c);
}
void write(const char *s) {
size_t len = strlen(s);
for (size_t i = 0; i < len; i++) write(s[i]);
}
void write(const double x) {
ostringstream oss;
oss << fixed << setprecision(15) << x;
string s = oss.str();
write(s);
}
void write(const long double x) {
ostringstream oss;
oss << fixed << setprecision(15) << x;
string s = oss.str();
write(s);
}
template <typename T,
typename enable_if<has_write<T>::value>::type * = nullptr>
inline void write(T x) {
x.write();
}
template <class T>
void write(const vector<T> val) {
auto n = val.size();
for (size_t i = 0; i < n; i++) {
if (i) write(' ');
write(val[i]);
}
}
template <class T, class U>
void write(const pair<T, U> val) {
write(val.first);
write(' ');
write(val.second);
}
template <size_t N = 0, typename T>
void write_tuple(const T t) {
if constexpr (N < std::tuple_size<T>::value) {
if constexpr (N > 0) { write(' '); }
const auto x = std::get<N>(t);
write(x);
write_tuple<N + 1>(t);
}
}
template <class... T>
bool write(tuple<T...> tpl) {
write_tuple(tpl);
return true;
}
template <class T, size_t S>
void write(const array<T, S> val) {
auto n = val.size();
for (size_t i = 0; i < n; i++) {
if (i) write(' ');
write(val[i]);
}
}
void write(i128 val) {
string s;
bool negative = 0;
if (val < 0) {
negative = 1;
val = -val;
}
while (val) {
s += '0' + int(val % 10);
val /= 10;
}
if (negative) s += "-";
reverse(all(s));
if (len(s) == 0) s = "0";
write(s);
}
};
Scanner scanner = Scanner(stdin);
Printer printer = Printer(stdout);
void flush() { printer.flush(); }
void print() { printer.write('\n'); }
template <class Head, class... Tail>
void print(Head &&head, Tail &&... tail) {
printer.write(head);
if (sizeof...(Tail)) printer.write(' ');
print(forward<Tail>(tail)...);
}
void read() {}
template <class Head, class... Tail>
void read(Head &head, Tail &... tail) {
scanner.read(head);
read(tail...);
}
} // namespace fastio
using fastio::print;
using fastio::flush;
using fastio::read;
#define INT(...) \
int __VA_ARGS__; \
read(__VA_ARGS__)
#define LL(...) \
ll __VA_ARGS__; \
read(__VA_ARGS__)
#define STR(...) \
string __VA_ARGS__; \
read(__VA_ARGS__)
#define CHAR(...) \
char __VA_ARGS__; \
read(__VA_ARGS__)
#define DBL(...) \
double __VA_ARGS__; \
read(__VA_ARGS__)
#define VEC(type, name, size) \
vector<type> name(size); \
read(name)
#define VV(type, name, h, w) \
vector<vector<type>> name(h, vector<type>(w)); \
read(name)
void YES(bool t = 1) { print(t ? "YES" : "NO"); }
void NO(bool t = 1) { YES(!t); }
void Yes(bool t = 1) { print(t ? "Yes" : "No"); }
void No(bool t = 1) { Yes(!t); }
void yes(bool t = 1) { print(t ? "yes" : "no"); }
void no(bool t = 1) { yes(!t); }
#line 2 "library/ds/segtree/dual_segtree.hpp"
template <typename Monoid>
struct Dual_SegTree {
using MA = Monoid;
using A = typename MA::value_type;
int n, log, size;
vc<A> laz;
Dual_SegTree() : Dual_SegTree(0) {}
Dual_SegTree(int n) { build(n); }
void build(int m) {
n = m;
log = 1;
while ((1 << log) < n) ++log;
size = 1 << log;
laz.assign(size << 1, MA::unit());
}
A get(int p) {
assert(0 <= p && p < n);
p += size;
for (int i = log; i >= 1; i--) push(p >> i);
return laz[p];
}
vc<A> get_all() {
FOR(i, size) push(i);
return {laz.begin() + size, laz.begin() + size + n};
}
void apply(int l, int r, const A& a) {
assert(0 <= l && l <= r && r <= n);
if (l == r) return;
l += size, r += size;
if (!MA::commute) {
for (int i = log; i >= 1; i--) {
if (((l >> i) << i) != l) push(l >> i);
if (((r >> i) << i) != r) push((r - 1) >> i);
}
}
while (l < r) {
if (l & 1) all_apply(l++, a);
if (r & 1) all_apply(--r, a);
l >>= 1, r >>= 1;
}
}
private:
void push(int k) {
if (laz[k] == MA::unit()) return;
all_apply(2 * k, laz[k]), all_apply(2 * k + 1, laz[k]);
laz[k] = MA::unit();
}
void all_apply(int k, A a) { laz[k] = MA::op(laz[k], a); }
};
#line 2 "library/alg/monoid/max.hpp"
template <typename E>
struct Monoid_Max {
using X = E;
using value_type = X;
static constexpr X op(const X &x, const X &y) noexcept { return max(x, y); }
static constexpr X unit() { return -infty<E>; }
static constexpr bool commute = true;
};
#line 2 "library/alg/monoid/add.hpp"
template <typename X>
struct Monoid_Add {
using value_type = X;
static constexpr X op(const X &x, const X &y) noexcept { return x + y; }
static constexpr X inverse(const X &x) noexcept { return -x; }
static constexpr X power(const X &x, ll n) noexcept { return X(n) * x; }
static constexpr X unit() { return X(0); }
static constexpr bool commute = true;
};
#line 2 "library/ds/doubling.hpp"
// 状態 a から 1 回操作すると、状態 b に遷移し、モノイドの元 x を加える。
// 行き先がない場合:-1 (add 不要)
template <typename Monoid, int LOG>
struct Doubling {
using X = typename Monoid::value_type;
int N;
bool is_prepared;
vvc<int> TO;
vvc<X> DP;
Doubling(int N) : N(N), is_prepared(0) {
TO.assign(LOG, vc<int>(N, -1));
DP.assign(LOG, vc<X>(N, Monoid::unit()));
}
void add(int i, int to, X x) {
assert(!is_prepared);
assert(-1 <= to && to < N);
TO[0][i] = to;
DP[0][i] = x;
}
void build() {
assert(!is_prepared);
is_prepared = 1;
FOR(k, LOG - 1) {
FOR(v, N) {
int w = TO[k][v];
if (w == -1) {
TO[k + 1][v] = -1;
DP[k + 1][v] = DP[k][v];
continue;
}
TO[k + 1][v] = TO[k][w];
DP[k + 1][v] = Monoid::op(DP[k][v], DP[k][w]);
}
}
}
// (to, val)
pair<int, X> calc(int i, ll step) {
assert(is_prepared);
assert(step < (1LL << LOG));
X x = Monoid::unit();
FOR(k, LOG) {
if (i == -1) break;
if (step & 1LL << k) {
x = Monoid::op(x, DP[k][i]);
i = TO[k][i];
}
}
return {i, x};
}
template <typename F>
ll max_step(F check, int i) {
assert(is_prepared);
X x = Monoid::unit();
ll step = 0;
assert(check(x));
FOR_R(k, LOG) {
int j = TO[k][i];
X y = Monoid::op(x, DP[k][i]);
if (check(y)) {
step |= 1LL << k;
i = j;
x = y;
assert(i != -1);
}
}
return step;
}
void debug() {
print("TO");
FOR(k, LOG) print(TO[k]);
print("DP");
FOR(k, LOG) print(DP[k]);
}
};
#line 6 "main.cpp"
// 移動回数、個数、和
struct Mono {
using value_type = array<ll, 3>;
using X = value_type;
static X op(X x, X y) {
return {x[0] + y[0], x[1] + y[1], x[2] + y[2] + x[0] * y[1]};
}
static constexpr X unit() { return {0, 0, 0}; }
static constexpr bool commute = 0;
};
void solve() {
LL(N);
VEC(pi, dat, N);
for (auto&& [a, b]: dat) --a, --b;
vi ANS(N);
vi done(N);
// cnt, sum
FOR(2) {
for (auto&& [a, b]: dat) tie(a, b) = mp(N + N - 1 - b, N + N - 1 - a);
// L
vc<int> L(N + N);
for (auto&& [a, b]: dat) L[a]++;
vc<int> Lc = cumsum<int>(L);
Dual_SegTree<Monoid_Max<int>> seg(N + N);
for (auto&& [a, b]: dat) seg.apply(a, b + 1, b);
auto TO = seg.get_all();
Doubling<Mono, 20> X(N + N);
FOR(i, N + N) {
int j = TO[i];
X.add(i, j, {1, (Lc[j] - Lc[i]), 2 * (Lc[j] - Lc[i])});
}
X.build();
FOR(i, N) {
auto [a, b] = dat[i];
auto [to, x] = X.calc(b, N + N + 10);
done[i] += x[1];
ANS[i] += x[2];
done[i] += Lc[N + N] - Lc[to];
}
}
FOR(i, N) ANS[i] += N - done[i] - 1;
for (auto&& x: ANS) print(x);
}
signed main() {
solve();
return 0;
}
詳細信息
Test #1:
score: 100
Accepted
time: 2ms
memory: 3440kb
input:
5 2 3 6 7 1 9 5 10 4 8
output:
7 5 4 5 5
result:
ok 5 number(s): "7 5 4 5 5"
Test #2:
score: 0
Accepted
time: 380ms
memory: 247944kb
input:
200000 342504 342505 248314 248317 259328 259334 234817 234821 225726 225732 371424 371425 260562 260565 34752 34753 132098 132100 262130 262134 7254 7255 228491 228492 43488 43492 188408 188410 11691 11692 350334 350335 327350 327352 360684 360685 182051 182052 72131 72135 194666 194668 61303 61313...
output:
12 21 17 6 16 33 2 1 1 19 6 0 25 19 7 11 2 20 14 8 2 11 0 1 0 2 38 35 28 6 4 0 23 22 17 10 26 10 5 9 1 16 14 24 7 1 2 40 18 18 19 13 4 26 2 28 0 0 39 19 0 37 4 13 18 19 23 14 2 4 0 40 10 0 1 6 52 7 1 18 3 6 1 40 7 24 16 13 31 43 4 10 23 20 1 0 4 4 0 1 8 3 1 17 37 14 43 5 17 32 60 0 0 0 28 0 18 16 7 ...
result:
ok 200000 numbers
Test #3:
score: 0
Accepted
time: 379ms
memory: 247876kb
input:
200000 26851 26856 258158 258160 332869 332878 28073 28074 65883 65898 181844 181847 162628 162633 293275 293276 107389 107398 302056 302072 95036 95038 311987 311988 279551 279552 86 87 161331 161332 3744 3747 231020 231024 42346 42352 37146 37153 294389 294406 265867 265873 246877 246881 197614 19...
output:
64 88 81 99 668 386 308 28 42 250 22 139 3979 331 623 312 1530 770 469 206 284 259 767 1503 221 130 686 331 98 232 865 162 1649 43 130 1144 94 413 889 1861 211 762 28 836 116 162 548 225 86 1561 319 617 4127 474 96 50 1580 1558 1435 86 465 1700 15 2 99 103 136 723 1510 12 1400 223 1271 37 61 597 27 ...
result:
ok 200000 numbers
Test #4:
score: 0
Accepted
time: 274ms
memory: 247736kb
input:
200000 337751 337758 110061 110077 324990 324993 352241 352247 325108 325115 134703 134717 25943 25962 121564 121573 42982 42983 248049 248087 60651 60657 332816 332828 246046 246055 304157 304158 392634 392640 111165 111171 247498 247513 86504 86506 185219 185235 69067 69083 251182 251183 279617 27...
output:
16419 361082 40617 418545 43244 82277 11271 258885 34898 614083 42296 147399 500813 314012 2834 277734 562298 80980 69570 394765 218205 1044173 15936 326857 97086 3675 156364 343907 125715 937181 353740 544767 183548 441107 59345 82190 185443 72848 247562 273053 495863 86049 444566 136148 356787 152...
result:
ok 200000 numbers
Test #5:
score: 0
Accepted
time: 288ms
memory: 247764kb
input:
200000 127219 127280 223345 223361 152880 152884 40178 40179 7991 8005 266310 266319 332397 332422 36392 36426 75573 75574 60879 60884 95868 95913 217855 217886 131673 131681 256534 256554 223529 223530 232350 232375 120809 120827 266098 266114 25711 25751 229072 229087 272840 272879 92506 92550 773...
output:
379221319 339344076 353506130 547752191 642034502 371778846 481200270 557918532 464406514 497231703 425782610 337490404 374130659 361866758 339437880 343683647 386790159 371580284 587088809 341994919 379226219 432022481 460538970 435287365 347076374 583445677 337619137 435205438 397389207 340450981 ...
result:
ok 200000 numbers
Test #6:
score: 0
Accepted
time: 265ms
memory: 247776kb
input:
200000 171936 172110 4591 4626 108508 108553 226874 226900 90791 90850 238982 238992 243153 243174 240390 240497 347627 347662 228287 228289 170781 170934 51097 51352 139750 139808 94804 94815 442 448 297474 297475 244036 244044 356100 356114 245963 245994 142149 142166 246792 246800 19022 19108 134...
output:
106189288 204472003 125920212 106000251 135642421 108056086 108997814 108214268 160512585 106193968 106360793 162247947 113429983 133438779 208813035 128560690 109094447 167473840 109589801 112792068 109898387 190365960 195890606 105339565 194960387 104526312 173066763 182424123 188124166 156349884 ...
result:
ok 200000 numbers
Test #7:
score: 0
Accepted
time: 258ms
memory: 247820kb
input:
200000 67879 67940 10416 10465 327752 327767 135984 135994 73978 74069 194780 195094 391551 391561 105509 105572 396552 396608 49997 50157 368719 368738 208681 208769 216212 216310 46486 46539 194253 194539 25014 25049 234319 234521 159508 159600 392891 393243 295417 295887 220115 220217 108196 1082...
output:
64734580 85174386 62791748 49363982 62670510 44740694 85882512 54835645 88015994 70235070 76674604 44894964 45118612 71297646 44847466 79519941 46079850 46733016 86455586 54596042 45354246 54277341 71781887 46735752 59856019 58595450 60747185 45149383 65402310 83057043 47809279 45603991 70890939 560...
result:
ok 200000 numbers
Test #8:
score: 0
Accepted
time: 264ms
memory: 247684kb
input:
200000 286770 286880 206693 206740 224293 224808 127509 127679 305483 305814 292326 292854 226829 226949 16092 16146 382375 383028 139098 139136 42306 42462 85808 85960 391657 391743 75339 75656 374612 374790 324858 325163 126952 127012 93957 94097 133574 133760 326872 326927 95947 96935 101356 1014...
output:
23436316 19895692 20084548 22447756 25407740 23973874 20137342 35924514 36421534 21647005 31664586 25936117 38296098 27283764 35181820 27792866 22385314 25166580 21898086 28045156 24849932 24493238 22857265 22519996 37724107 25514267 20496978 20449635 27284206 37166496 20312154 25408786 26557231 364...
result:
ok 200000 numbers
Test #9:
score: 0
Accepted
time: 251ms
memory: 247740kb
input:
200000 380316 380382 211990 212332 98342 98497 273741 274028 310348 310373 15880 16509 377455 377930 30217 30927 327310 327466 34478 35491 381454 382262 133424 133425 338230 338939 201253 201418 315547 316660 129756 129908 8865 8967 290213 290918 200810 201836 363765 364427 266183 267070 150404 1505...
output:
12162580 6900400 8749178 7780778 9122073 12431434 11974806 11726400 9719653 11557873 12154465 7729331 10087943 6877024 9233382 7736819 12994846 8272476 6874728 11469762 7572458 7377010 8961745 8556622 11978523 9234003 6777657 9352548 9264121 12714264 11147516 12713648 10666576 12615729 7939879 68755...
result:
ok 200000 numbers
Test #10:
score: 0
Accepted
time: 232ms
memory: 247724kb
input:
200000 94172 94549 378164 379641 98214 99014 32105 32115 161647 162954 150359 150544 310360 310419 354635 355536 165664 167834 82402 84493 325499 325550 307332 307497 332558 333000 38917 39174 346142 350743 91220 91402 214569 215415 177931 178010 197235 197762 68559 69705 376546 380294 127708 129140...
output:
4111828 5416403 4015502 5365302 3311594 3420049 4124495 4922006 3376096 4231851 4366457 4003214 4336910 5039206 4751726 4121666 3211927 3322124 3283548 4463047 5415273 3579780 4496188 3420213 3526465 3832293 4886321 4737354 5788810 4770208 3641455 3377048 3352478 4922204 3321986 3916692 4359401 5535...
result:
ok 200000 numbers
Test #11:
score: 0
Accepted
time: 253ms
memory: 247672kb
input:
200000 1072 3118 40071 43871 127286 133342 225846 229162 107755 108681 126692 126984 282893 289606 371786 372185 323077 326187 115603 116808 371356 373473 297233 297757 69577 69663 115940 116991 222525 223825 258843 260753 116418 117598 364675 364863 390718 392788 176166 182649 309256 312248 231780 ...
output:
2825812 2456257 1722533 1619155 1938198 1780319 1839986 2651546 2095849 1802614 2642653 1969729 2171015 1802669 1667585 1734749 1802593 2480030 2829784 1583490 1975708 1591427 1975008 1881362 2160968 2037564 2192449 2022100 1932643 1975777 2464278 2455552 1661653 1802541 1976558 1846501 1797272 2463...
result:
ok 200000 numbers
Test #12:
score: 0
Accepted
time: 245ms
memory: 247804kb
input:
200000 172930 174742 27463 29558 281470 282104 378322 381194 289478 290375 293078 317404 324947 325056 105107 111280 254153 254706 32188 37595 318055 321344 112598 118650 269551 270153 343739 345290 266354 271907 363821 369134 383270 389836 251225 265879 117980 126149 4042 14067 10229 11087 116790 1...
output:
741968 1125299 873370 1176638 867970 833651 980787 856194 800813 1116499 883021 856239 806684 1015473 791463 1119436 1180387 792430 823849 1149950 1154489 747812 973592 1113694 888796 974015 974926 739982 858574 774214 935522 822716 887233 740193 739779 1109462 1114910 1010604 872778 796867 1174921 ...
result:
ok 200000 numbers
Test #13:
score: 0
Accepted
time: 248ms
memory: 247680kb
input:
200000 396480 397307 35648 37415 256941 267156 135654 139714 126330 133123 237210 241635 9328 12129 138460 145503 292776 294347 51995 53415 327655 329591 367790 368757 41948 58528 12606 56450 224903 237674 47356 51357 177950 193567 16051 34504 25665 27391 392399 392798 21152 40393 12230 38747 292065...
output:
757703 687976 530266 498832 566176 517902 728283 503183 592078 605230 603367 685120 597626 584013 513710 603917 513028 679635 724620 730945 652828 675589 574078 726230 528058 607213 530516 499502 592079 516952 522796 590211 500171 724355 453484 597863 580815 603151 522371 503484 531015 756377 497243...
result:
ok 200000 numbers
Test #14:
score: 0
Accepted
time: 304ms
memory: 247704kb
input:
200000 172883 218174 30687 56660 211338 242591 318600 323262 63226 97641 269157 284103 33990 43988 192237 196395 247512 254586 33563 38944 83379 117561 10925 12071 262370 266422 100154 111153 238382 280045 192961 220350 297213 396676 265697 302673 296937 327287 370554 390222 71247 100334 384661 3954...
output:
362419 407362 369316 412008 367790 377817 415298 382767 381560 417652 367851 436485 383164 379539 364214 371254 351223 366756 379800 413831 370459 427185 326780 371524 430064 381207 370442 417530 386226 375423 383241 411644 360743 379011 375728 413952 365596 404176 371097 420988 382996 413505 370805...
result:
ok 200000 numbers
Test #15:
score: 0
Accepted
time: 281ms
memory: 247900kb
input:
200000 103349 264305 178051 198663 74656 100424 322291 333624 62219 116581 21852 44028 251919 277878 53240 87351 245100 265874 11996 40044 212372 225176 73628 149628 142790 310770 169496 247976 50308 180800 138992 330125 289117 338022 274751 382694 80345 101657 2111 76369 33407 71723 63648 118011 18...
output:
271317 340356 338924 356175 326660 362113 340270 339117 342221 364406 344791 313916 270169 312019 291326 260668 335469 315720 340553 338288 344095 326412 301682 297778 360096 315745 385982 257349 258225 300578 330067 230799 309768 321414 322127 310177 297449 266039 328487 368521 338380 345179 341038...
result:
ok 200000 numbers
Test #16:
score: 0
Accepted
time: 289ms
memory: 247820kb
input:
200000 118304 262258 30805 129796 105610 215004 73169 305825 16186 104979 162259 187539 265974 385486 186957 352497 64058 269854 9282 141856 216553 269728 24364 78747 172872 286230 71411 360129 142836 348733 232833 282395 45897 112265 137827 213006 38139 171233 24943 118081 43184 311266 22521 112855...
output:
242013 292713 257381 218694 309268 290166 289419 247559 226922 283711 281043 329730 254674 208770 229742 286364 306217 268277 267600 300285 213136 303829 280878 282830 338182 279645 280853 291142 226678 298078 264998 309417 233019 224610 274302 344537 258601 271299 311937 238976 212577 274349 234122...
result:
ok 200000 numbers
Test #17:
score: 0
Accepted
time: 274ms
memory: 247856kb
input:
200000 201425 347551 71476 137629 140154 376332 116590 341032 210807 331824 245972 388020 5575 334517 163518 251275 138978 227516 201756 383479 8395 372874 56793 233450 294485 318492 146791 396767 164811 285272 287563 307750 145795 341549 179229 186820 176893 223994 2860 199806 270613 351304 113107 ...
output:
254146 292218 225197 221335 261420 275659 205466 260965 261245 251184 201018 238547 316664 226860 250393 313980 230771 296931 277857 250070 294536 248236 218502 319837 356166 238661 299729 218683 209705 332155 343658 308842 269694 287381 268875 278393 310296 245233 340731 291962 299710 275388 279549...
result:
ok 200000 numbers