QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#853076#9729. Dividing Sequenceucup-team987#AC ✓69ms31556kbC++2323.6kb2025-01-11 15:34:142025-01-11 15:34:20

Judging History

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

  • [2025-01-11 15:34:20]
  • 评测
  • 测评结果:AC
  • 用时:69ms
  • 内存:31556kb
  • [2025-01-11 15:34:14]
  • 提交

answer

/**
 * date   : 2025-01-11 16:33:58
 * author : Nyaan
 */

#define NDEBUG

using namespace std;

// intrinstic
#include <immintrin.h>

#include <algorithm>
#include <array>
#include <bitset>
#include <cassert>
#include <cctype>
#include <cfenv>
#include <cfloat>
#include <chrono>
#include <cinttypes>
#include <climits>
#include <cmath>
#include <complex>
#include <cstdarg>
#include <cstddef>
#include <cstdint>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <deque>
#include <fstream>
#include <functional>
#include <initializer_list>
#include <iomanip>
#include <ios>
#include <iostream>
#include <istream>
#include <iterator>
#include <limits>
#include <list>
#include <map>
#include <memory>
#include <new>
#include <numeric>
#include <ostream>
#include <queue>
#include <random>
#include <set>
#include <sstream>
#include <stack>
#include <streambuf>
#include <string>
#include <tr2/dynamic_bitset>
#include <tuple>
#include <type_traits>
#include <typeinfo>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>

// utility

namespace Nyaan {
using ll = long long;
using i64 = long long;
using u64 = unsigned long long;
using i128 = __int128_t;
using u128 = __uint128_t;

template <typename T>
using V = vector<T>;
template <typename T>
using VV = vector<vector<T>>;
using vi = vector<int>;
using vl = vector<long long>;
using vd = V<double>;
using vs = V<string>;
using vvi = vector<vector<int>>;
using vvl = vector<vector<long long>>;
template <typename T>
using minpq = priority_queue<T, vector<T>, greater<T>>;

template <typename T, typename U>
struct P : pair<T, U> {
  template <typename... Args>
  constexpr P(Args... args) : pair<T, U>(args...) {}

  using pair<T, U>::first;
  using pair<T, U>::second;

  P &operator+=(const P &r) {
    first += r.first;
    second += r.second;
    return *this;
  }
  P &operator-=(const P &r) {
    first -= r.first;
    second -= r.second;
    return *this;
  }
  P &operator*=(const P &r) {
    first *= r.first;
    second *= r.second;
    return *this;
  }
  template <typename S>
  P &operator*=(const S &r) {
    first *= r, second *= r;
    return *this;
  }
  P operator+(const P &r) const { return P(*this) += r; }
  P operator-(const P &r) const { return P(*this) -= r; }
  P operator*(const P &r) const { return P(*this) *= r; }
  template <typename S>
  P operator*(const S &r) const {
    return P(*this) *= r;
  }
  P operator-() const { return P{-first, -second}; }
};

using pl = P<ll, ll>;
using pi = P<int, int>;
using vp = V<pl>;

constexpr int inf = 1001001001;
constexpr long long infLL = 4004004004004004004LL;

template <typename T>
int sz(const T &t) {
  return t.size();
}

template <typename T, typename U>
inline bool amin(T &x, U y) {
  return (y < x) ? (x = y, true) : false;
}
template <typename T, typename U>
inline bool amax(T &x, U y) {
  return (x < y) ? (x = y, true) : false;
}

template <typename T>
inline T Max(const vector<T> &v) {
  return *max_element(begin(v), end(v));
}
template <typename T>
inline T Min(const vector<T> &v) {
  return *min_element(begin(v), end(v));
}
template <typename T>
inline long long Sum(const vector<T> &v) {
  return accumulate(begin(v), end(v), 0LL);
}

template <typename T>
int lb(const vector<T> &v, const T &a) {
  return lower_bound(begin(v), end(v), a) - begin(v);
}
template <typename T>
int ub(const vector<T> &v, const T &a) {
  return upper_bound(begin(v), end(v), a) - begin(v);
}

constexpr long long TEN(int n) {
  long long ret = 1, x = 10;
  for (; n; x *= x, n >>= 1) ret *= (n & 1 ? x : 1);
  return ret;
}

template <typename T, typename U>
pair<T, U> mkp(const T &t, const U &u) {
  return make_pair(t, u);
}

template <typename T>
vector<T> mkrui(const vector<T> &v, bool rev = false) {
  vector<T> ret(v.size() + 1);
  if (rev) {
    for (int i = int(v.size()) - 1; i >= 0; i--) ret[i] = v[i] + ret[i + 1];
  } else {
    for (int i = 0; i < int(v.size()); i++) ret[i + 1] = ret[i] + v[i];
  }
  return ret;
};

template <typename T>
vector<T> mkuni(const vector<T> &v) {
  vector<T> ret(v);
  sort(ret.begin(), ret.end());
  ret.erase(unique(ret.begin(), ret.end()), ret.end());
  return ret;
}

template <typename F>
vector<int> mkord(int N, F f) {
  vector<int> ord(N);
  iota(begin(ord), end(ord), 0);
  sort(begin(ord), end(ord), f);
  return ord;
}

template <typename T>
vector<int> mkinv(vector<T> &v) {
  int max_val = *max_element(begin(v), end(v));
  vector<int> inv(max_val + 1, -1);
  for (int i = 0; i < (int)v.size(); i++) inv[v[i]] = i;
  return inv;
}

vector<int> mkiota(int n) {
  vector<int> ret(n);
  iota(begin(ret), end(ret), 0);
  return ret;
}

template <typename T>
T mkrev(const T &v) {
  T w{v};
  reverse(begin(w), end(w));
  return w;
}

template <typename T>
bool nxp(T &v) {
  return next_permutation(begin(v), end(v));
}

// 返り値の型は入力の T に依存
// i 要素目 : [0, a[i])
template <typename T>
vector<vector<T>> product(const vector<T> &a) {
  vector<vector<T>> ret;
  vector<T> v;
  auto dfs = [&](auto rc, int i) -> void {
    if (i == (int)a.size()) {
      ret.push_back(v);
      return;
    }
    for (int j = 0; j < a[i]; j++) v.push_back(j), rc(rc, i + 1), v.pop_back();
  };
  dfs(dfs, 0);
  return ret;
}

// F : function(void(T&)), mod を取る操作
// T : 整数型のときはオーバーフローに注意する
template <typename T>
T Power(T a, long long n, const T &I, const function<void(T &)> &f) {
  T res = I;
  for (; n; f(a = a * a), n >>= 1) {
    if (n & 1) f(res = res * a);
  }
  return res;
}
// T : 整数型のときはオーバーフローに注意する
template <typename T>
T Power(T a, long long n, const T &I = T{1}) {
  return Power(a, n, I, function<void(T &)>{[](T &) -> void {}});
}

template <typename T>
T Rev(const T &v) {
  T res = v;
  reverse(begin(res), end(res));
  return res;
}

template <typename T>
vector<T> Transpose(const vector<T> &v) {
  using U = typename T::value_type;
  if(v.empty()) return {};
  int H = v.size(), W = v[0].size();
  vector res(W, T(H, U{}));
  for (int i = 0; i < H; i++) {
    for (int j = 0; j < W; j++) {
      res[j][i] = v[i][j];
    }
  }
  return res;
}

template <typename T>
vector<T> Rotate(const vector<T> &v, int clockwise = true) {
  using U = typename T::value_type;
  int H = v.size(), W = v[0].size();
  vector res(W, T(H, U{}));
  for (int i = 0; i < H; i++) {
    for (int j = 0; j < W; j++) {
      if (clockwise) {
        res[W - 1 - j][i] = v[i][j];
      } else {
        res[j][H - 1 - i] = v[i][j];
      }
    }
  }
  return res;
}

}  // namespace Nyaan


// bit operation

namespace Nyaan {
__attribute__((target("popcnt"))) inline int popcnt(const u64 &a) {
  return __builtin_popcountll(a);
}
inline int lsb(const u64 &a) { return a ? __builtin_ctzll(a) : 64; }
inline int ctz(const u64 &a) { return a ? __builtin_ctzll(a) : 64; }
inline int msb(const u64 &a) { return a ? 63 - __builtin_clzll(a) : -1; }
template <typename T>
inline int gbit(const T &a, int i) {
  return (a >> i) & 1;
}
template <typename T>
inline void sbit(T &a, int i, bool b) {
  if (gbit(a, i) != b) a ^= T(1) << i;
}
constexpr long long PW(int n) { return 1LL << n; }
constexpr long long MSK(int n) { return (1LL << n) - 1; }
}  // namespace Nyaan


// inout

namespace Nyaan {

template <typename T, typename U>
ostream &operator<<(ostream &os, const pair<T, U> &p) {
  os << p.first << " " << p.second;
  return os;
}
template <typename T, typename U>
istream &operator>>(istream &is, pair<T, U> &p) {
  is >> p.first >> p.second;
  return is;
}

template <typename T>
ostream &operator<<(ostream &os, const vector<T> &v) {
  int s = (int)v.size();
  for (int i = 0; i < s; i++) os << (i ? " " : "") << v[i];
  return os;
}
template <typename T>
istream &operator>>(istream &is, vector<T> &v) {
  for (auto &x : v) is >> x;
  return is;
}

istream &operator>>(istream &is, __int128_t &x) {
  string S;
  is >> S;
  x = 0;
  int flag = 0;
  for (auto &c : S) {
    if (c == '-') {
      flag = true;
      continue;
    }
    x *= 10;
    x += c - '0';
  }
  if (flag) x = -x;
  return is;
}

istream &operator>>(istream &is, __uint128_t &x) {
  string S;
  is >> S;
  x = 0;
  for (auto &c : S) {
    x *= 10;
    x += c - '0';
  }
  return is;
}

ostream &operator<<(ostream &os, __int128_t x) {
  if (x == 0) return os << 0;
  if (x < 0) os << '-', x = -x;
  string S;
  while (x) S.push_back('0' + x % 10), x /= 10;
  reverse(begin(S), end(S));
  return os << S;
}
ostream &operator<<(ostream &os, __uint128_t x) {
  if (x == 0) return os << 0;
  string S;
  while (x) S.push_back('0' + x % 10), x /= 10;
  reverse(begin(S), end(S));
  return os << S;
}

void in() {}
template <typename T, class... U>
void in(T &t, U &...u) {
  cin >> t;
  in(u...);
}

void out() { cout << "\n"; }
template <typename T, class... U, char sep = ' '>
void out(const T &t, const U &...u) {
  cout << t;
  if (sizeof...(u)) cout << sep;
  out(u...);
}

struct IoSetupNya {
  IoSetupNya() {
    cin.tie(nullptr);
    ios::sync_with_stdio(false);
    cout << fixed << setprecision(15);
    cerr << fixed << setprecision(7);
  }
} iosetupnya;

}  // namespace Nyaan


// debug


#ifdef NyaanDebug
#define trc(...) (void(0))
#else
#define trc(...) (void(0))
#endif

#ifdef NyaanLocal
#define trc2(...) (void(0))
#else
#define trc2(...) (void(0))
#endif


// macro

#define each(x, v) for (auto&& x : v)
#define each2(x, y, v) for (auto&& [x, y] : v)
#define all(v) (v).begin(), (v).end()
#define rep(i, N) for (long long i = 0; i < (long long)(N); i++)
#define repr(i, N) for (long long i = (long long)(N)-1; i >= 0; i--)
#define rep1(i, N) for (long long i = 1; i <= (long long)(N); i++)
#define repr1(i, N) for (long long i = (N); (long long)(i) > 0; i--)
#define reg(i, a, b) for (long long i = (a); i < (b); i++)
#define regr(i, a, b) for (long long i = (b)-1; i >= (a); i--)
#define fi first
#define se second
#define ini(...)   \
  int __VA_ARGS__; \
  in(__VA_ARGS__)
#define inl(...)         \
  long long __VA_ARGS__; \
  in(__VA_ARGS__)
#define ins(...)      \
  string __VA_ARGS__; \
  in(__VA_ARGS__)
#define in2(s, t)                           \
  for (int i = 0; i < (int)s.size(); i++) { \
    in(s[i], t[i]);                         \
  }
#define in3(s, t, u)                        \
  for (int i = 0; i < (int)s.size(); i++) { \
    in(s[i], t[i], u[i]);                   \
  }
#define in4(s, t, u, v)                     \
  for (int i = 0; i < (int)s.size(); i++) { \
    in(s[i], t[i], u[i], v[i]);             \
  }
#define die(...)             \
  do {                       \
    Nyaan::out(__VA_ARGS__); \
    return;                  \
  } while (0)


namespace Nyaan {
void solve();
}
int main() { Nyaan::solve(); }


//



using namespace std;



template <typename Container>
vector<int> z_algorithm(const Container& s) {
  int n = s.size();
  if(n == 0) return {};
  vector<int> a(n);
  a[0] = n;
  int i = 1, j = 0;
  while (i < n) {
    while (i + j < n && s[j] == s[i + j]) j++;
    a[i] = j;
    if (j == 0) {
      i++;
      continue;
    }
    int k = 1;
    while (i + k < n && k + a[k] < j) a[i + k] = a[k], k++;
    i += k, j -= k;
  }
  return a;
}

/**
 * @brief Z algorithm
 */


// (p, l, r) : S[l, r) は周期 p かつ極大
// sum_{(p,l,r)} 1 <= n
// sum_{(p,l,r)} (r-l)/p <= 3n
// sum_{(p,l,r)} (r-l+1-2*p) = O(n log n)
template <typename C>
vector<tuple<int, int, int>> run_enumerate(const C& S) {
  int N = S.size();
  using T = tuple<int, int, int>;
  vector<vector<pair<int, int>>> by_p(N + 1);

  auto solve_sub = [&](const C& l, const C& r) {
    vector<T> res;
    int n = l.size(), m = r.size();
    C s = l, t = r;
    t.insert(end(t), begin(l), end(l));
    t.insert(end(t), begin(r), end(r));
    reverse(begin(s), end(s));
    auto ZS = z_algorithm(s), ZT = z_algorithm(t);
    for (int p = 1; p <= n; p++) {
      int a = p == n ? p : min(ZS[p] + p, n);
      int b = min(ZT[n + m - p], m);
      if (a + b < 2 * p) continue;
      res.emplace_back(p, a, b);
    }
    return res;
  };

  auto dfs = [&](auto rc, int L, int R) -> void {
    if (R - L <= 1) return;
    int M = (L + R) / 2;
    rc(rc, L, M), rc(rc, M, R);
    C SL{begin(S) + L, begin(S) + M};
    C SR{begin(S) + M, begin(S) + R};
    auto sub_res1 = solve_sub(SL, SR);
    for (auto& [p, a, b] : sub_res1) by_p[p].emplace_back(M - a, M + b);
    reverse(begin(SL), end(SL));
    reverse(begin(SR), end(SR));
    auto sub_res2 = solve_sub(SR, SL);
    for (auto& [p, a, b] : sub_res2) by_p[p].emplace_back(M - b, M + a);
  };
  dfs(dfs, 0, N);

  vector<T> res;
  set<pair<int, int>> done;
  for (int p = 0; p <= N; p++) {
    auto& LR = by_p[p];
    sort(begin(LR), end(LR), [](auto& x, auto& y) {
      if (x.first == y.first) return x.second > y.second;
      return x.first < y.first;
    });
    int r = -1;
    for (auto& lr : LR) {
      if (r >= lr.second) continue;
      r = lr.second;
      if (!done.count(lr)) {
        done.insert(lr);
        res.emplace_back(p, lr.first, lr.second);
      }
    }
  }
  return res;
}








namespace atcoder {

namespace internal {

std::vector<int> sa_naive(const std::vector<int>& s) {
    int n = int(s.size());
    std::vector<int> sa(n);
    std::iota(sa.begin(), sa.end(), 0);
    std::sort(sa.begin(), sa.end(), [&](int l, int r) {
        if (l == r) return false;
        while (l < n && r < n) {
            if (s[l] != s[r]) return s[l] < s[r];
            l++;
            r++;
        }
        return l == n;
    });
    return sa;
}

std::vector<int> sa_doubling(const std::vector<int>& s) {
    int n = int(s.size());
    std::vector<int> sa(n), rnk = s, tmp(n);
    std::iota(sa.begin(), sa.end(), 0);
    for (int k = 1; k < n; k *= 2) {
        auto cmp = [&](int x, int y) {
            if (rnk[x] != rnk[y]) return rnk[x] < rnk[y];
            int rx = x + k < n ? rnk[x + k] : -1;
            int ry = y + k < n ? rnk[y + k] : -1;
            return rx < ry;
        };
        std::sort(sa.begin(), sa.end(), cmp);
        tmp[sa[0]] = 0;
        for (int i = 1; i < n; i++) {
            tmp[sa[i]] = tmp[sa[i - 1]] + (cmp(sa[i - 1], sa[i]) ? 1 : 0);
        }
        std::swap(tmp, rnk);
    }
    return sa;
}

// SA-IS, linear-time suffix array construction
// Reference:
// G. Nong, S. Zhang, and W. H. Chan,
// Two Efficient Algorithms for Linear Time Suffix Array Construction
template <int THRESHOLD_NAIVE = 10, int THRESHOLD_DOUBLING = 40>
std::vector<int> sa_is(const std::vector<int>& s, int upper) {
    int n = int(s.size());
    if (n == 0) return {};
    if (n == 1) return {0};
    if (n == 2) {
        if (s[0] < s[1]) {
            return {0, 1};
        } else {
            return {1, 0};
        }
    }
    if (n < THRESHOLD_NAIVE) {
        return sa_naive(s);
    }
    if (n < THRESHOLD_DOUBLING) {
        return sa_doubling(s);
    }

    std::vector<int> sa(n);
    std::vector<bool> ls(n);
    for (int i = n - 2; i >= 0; i--) {
        ls[i] = (s[i] == s[i + 1]) ? ls[i + 1] : (s[i] < s[i + 1]);
    }
    std::vector<int> sum_l(upper + 1), sum_s(upper + 1);
    for (int i = 0; i < n; i++) {
        if (!ls[i]) {
            sum_s[s[i]]++;
        } else {
            sum_l[s[i] + 1]++;
        }
    }
    for (int i = 0; i <= upper; i++) {
        sum_s[i] += sum_l[i];
        if (i < upper) sum_l[i + 1] += sum_s[i];
    }

    auto induce = [&](const std::vector<int>& lms) {
        std::fill(sa.begin(), sa.end(), -1);
        std::vector<int> buf(upper + 1);
        std::copy(sum_s.begin(), sum_s.end(), buf.begin());
        for (auto d : lms) {
            if (d == n) continue;
            sa[buf[s[d]]++] = d;
        }
        std::copy(sum_l.begin(), sum_l.end(), buf.begin());
        sa[buf[s[n - 1]]++] = n - 1;
        for (int i = 0; i < n; i++) {
            int v = sa[i];
            if (v >= 1 && !ls[v - 1]) {
                sa[buf[s[v - 1]]++] = v - 1;
            }
        }
        std::copy(sum_l.begin(), sum_l.end(), buf.begin());
        for (int i = n - 1; i >= 0; i--) {
            int v = sa[i];
            if (v >= 1 && ls[v - 1]) {
                sa[--buf[s[v - 1] + 1]] = v - 1;
            }
        }
    };

    std::vector<int> lms_map(n + 1, -1);
    int m = 0;
    for (int i = 1; i < n; i++) {
        if (!ls[i - 1] && ls[i]) {
            lms_map[i] = m++;
        }
    }
    std::vector<int> lms;
    lms.reserve(m);
    for (int i = 1; i < n; i++) {
        if (!ls[i - 1] && ls[i]) {
            lms.push_back(i);
        }
    }

    induce(lms);

    if (m) {
        std::vector<int> sorted_lms;
        sorted_lms.reserve(m);
        for (int v : sa) {
            if (lms_map[v] != -1) sorted_lms.push_back(v);
        }
        std::vector<int> rec_s(m);
        int rec_upper = 0;
        rec_s[lms_map[sorted_lms[0]]] = 0;
        for (int i = 1; i < m; i++) {
            int l = sorted_lms[i - 1], r = sorted_lms[i];
            int end_l = (lms_map[l] + 1 < m) ? lms[lms_map[l] + 1] : n;
            int end_r = (lms_map[r] + 1 < m) ? lms[lms_map[r] + 1] : n;
            bool same = true;
            if (end_l - l != end_r - r) {
                same = false;
            } else {
                while (l < end_l) {
                    if (s[l] != s[r]) {
                        break;
                    }
                    l++;
                    r++;
                }
                if (l == n || s[l] != s[r]) same = false;
            }
            if (!same) rec_upper++;
            rec_s[lms_map[sorted_lms[i]]] = rec_upper;
        }

        auto rec_sa =
            sa_is<THRESHOLD_NAIVE, THRESHOLD_DOUBLING>(rec_s, rec_upper);

        for (int i = 0; i < m; i++) {
            sorted_lms[i] = lms[rec_sa[i]];
        }
        induce(sorted_lms);
    }
    return sa;
}

}  // namespace internal

std::vector<int> suffix_array(const std::vector<int>& s, int upper) {
    assert(0 <= upper);
    for (int d : s) {
        assert(0 <= d && d <= upper);
    }
    auto sa = internal::sa_is(s, upper);
    return sa;
}

template <class T> std::vector<int> suffix_array(const std::vector<T>& s) {
    int n = int(s.size());
    std::vector<int> idx(n);
    iota(idx.begin(), idx.end(), 0);
    sort(idx.begin(), idx.end(), [&](int l, int r) { return s[l] < s[r]; });
    std::vector<int> s2(n);
    int now = 0;
    for (int i = 0; i < n; i++) {
        if (i && s[idx[i - 1]] != s[idx[i]]) now++;
        s2[idx[i]] = now;
    }
    return internal::sa_is(s2, now);
}

std::vector<int> suffix_array(const std::string& s) {
    int n = int(s.size());
    std::vector<int> s2(n);
    for (int i = 0; i < n; i++) {
        s2[i] = s[i];
    }
    return internal::sa_is(s2, 255);
}

// Reference:
// T. Kasai, G. Lee, H. Arimura, S. Arikawa, and K. Park,
// Linear-Time Longest-Common-Prefix Computation in Suffix Arrays and Its
// Applications
template <class T>
std::vector<int> lcp_array(const std::vector<T>& s,
                           const std::vector<int>& sa) {
    int n = int(s.size());
    assert(n >= 1);
    std::vector<int> rnk(n);
    for (int i = 0; i < n; i++) {
        rnk[sa[i]] = i;
    }
    std::vector<int> lcp(n - 1);
    int h = 0;
    for (int i = 0; i < n; i++) {
        if (h > 0) h--;
        if (rnk[i] == 0) continue;
        int j = sa[rnk[i] - 1];
        for (; j + h < n && i + h < n; h++) {
            if (s[j + h] != s[i + h]) break;
        }
        lcp[rnk[i] - 1] = h;
    }
    return lcp;
}

std::vector<int> lcp_array(const std::string& s, const std::vector<int>& sa) {
    int n = int(s.size());
    std::vector<int> s2(n);
    for (int i = 0; i < n; i++) {
        s2[i] = s[i];
    }
    return lcp_array(s2, sa);
}

// Reference:
// D. Gusfield,
// Algorithms on Strings, Trees, and Sequences: Computer Science and
// Computational Biology
template <class T> std::vector<int> z_algorithm(const std::vector<T>& s) {
    int n = int(s.size());
    if (n == 0) return {};
    std::vector<int> z(n);
    z[0] = 0;
    for (int i = 1, j = 0; i < n; i++) {
        int& k = z[i];
        k = (j + z[j] <= i) ? 0 : std::min(j + z[j] - i, z[i - j]);
        while (i + k < n && s[k] == s[i + k]) k++;
        if (j + z[j] < i + z[i]) j = i;
    }
    z[0] = n;
    return z;
}

std::vector<int> z_algorithm(const std::string& s) {
    int n = int(s.size());
    std::vector<int> s2(n);
    for (int i = 0; i < n; i++) {
        s2[i] = s[i];
    }
    return z_algorithm(s2);
}

}  // namespace atcoder




using namespace std;

template <typename T>
struct SparseTable {
  inline static constexpr T INF = numeric_limits<T>::max() / 2;
  int N;
  vector<vector<T> > table;
  T f(T a, T b) { return min(a, b); }
  SparseTable() {}
  SparseTable(const vector<T> &v) : N(v.size()) {
    int b = 1;
    while ((1 << b) <= N) ++b;
    table.push_back(v);
    for (int i = 1; i < b; i++) {
      table.push_back(vector<T>(N, INF));
      for (int j = 0; j + (1 << i) <= N; j++) {
        table[i][j] = f(table[i - 1][j], table[i - 1][j + (1 << (i - 1))]);
      }
    }
  }
  // [l, r)
  T query(int l, int r) {
    assert(0 <= l and l <= r and r <= N);
    if (l == r) return INF;
    int b = 31 - __builtin_clz(r - l);
    return f(table[b][l], table[b][r - (1 << b)]);
  }
};

/**
 * @brief Sparse Table
 */


template <typename Container>
struct StringSearch {
  const Container& S;
  int N;
  vector<int> sa, la, invsa;
  SparseTable<int> sparse;

  StringSearch(const Container& _s) : S(_s), N(S.size()) {
    sa = atcoder::suffix_array(S);
    la = atcoder::lcp_array(S, sa);
    invsa.resize(N);
    for (int i = 0; i < N; i++) invsa[sa[i]] = i;
    sparse = SparseTable<int>{la};
  }

  // lcp(s[i, N), s[j, N))
  int lcp(int i, int j) {
    assert(0 <= min(i, j) and max(i, j) < N);
    if (i == j) return N - i;
    int x = min(invsa[i], invsa[j]);
    int y = max(invsa[i], invsa[j]);
    return sparse.query(x, y);
  }
  // lcp(s[a, b), s[c, d))
  int lcp(int a, int b, int c, int d) {
    assert(0 <= a and a <= b and b <= N);
    assert(0 <= c and c <= d and d <= N);
    int l = lcp(a, c);
    return min({l, b - a, d - c});
  }
  // lcp(s[a, b), s[c, d))
  template <typename Int>
  int lcp(pair<Int, Int> p, pair<Int, Int> q) {
    return lcp(p.first, p.second, q.first, q.second);
  }

  // s[i, N) > s[j, N) : 1
  // s[i, N) = s[j, N) : 0
  // s[i, N) < s[j, N) : -1
  int strcmp(int i, int j) {
    assert(0 <= min(i, j) and max(i, j) < N);
    if (i == j) return 0;
    return invsa[i] < invsa[j] ? -1 : 1;
  }

  // s[a, b) > s[c, d) : 1
  // s[a, b) = s[c, d) : 0
  // s[a, b) < s[c, d) : -1
  int strcmp(int a, int b, int c, int d) {
    int l = lcp(a, b, c, d);
    return a + l == b            ? (c + l == d ? 0 : -1)
           : c + l == d          ? 1
           : S[a + l] < S[c + l] ? -1
                                 : 1;
  }
  // s[a, b) > s[c, d) : 1
  // s[a, b) = s[c, d) : 0
  // s[a, b) < s[c, d) : -1
  template <typename Int>
  int strcmp(pair<Int, Int> p, pair<Int, Int> q) {
    return strcmp(p.first, p.second, q.first, q.second);
  }
};


using namespace Nyaan;

vi calc(int N, vi A) {
  auto run = run_enumerate(A);
  StringSearch ss{A};

  vvi dst(N);
  for (auto& [p, l, r] : run) {
    reg(i, l, r) {
      if (i + 2 * p > r) break;
      dst[i].push_back(i + 2 * p);
    }
  }

  vvi ans(N + 1);
  repr(i, N) {
    vi best, v;
    {
      // [j,N) <= [i,j)
      reg(j, i + 1, N) {
        if (ss.strcmp(j, N, i, j) == -1) {
          best = vi{begin(A) + i, begin(A) + j};
          break;
        }
      }
      if (best.empty()) best = vi{begin(A) + i, end(A)};
    }
    trc(best);
    each(j, dst[i]) {
      int p = (j - i) / 2;
      v.clear();
      v.reserve(p + sz(ans[j]));
      copy(begin(A) + i, begin(A) + i + p, back_inserter(v));
      copy(begin(ans[j]), end(ans[j]), back_inserter(v));
      if (v < best) swap(best, v);
    }
    trc(i, best);
    ans[i] = best;
  }
  return ans[0];
}

void q() {
  ini(N);
  vi A(N);
  in(A);
  auto ans = calc(N, A);
  out(sz(ans));
  out(ans);
}

void Nyaan::solve() {
  int t = 1;
  in(t);
  while (t--) q();
}

这程序好像有点Bug,我给组数据试试?

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 1ms
memory: 3840kb

input:

5
5
3 1 2 3 2
3
1 1 2
3
3 3 3
5
1 3 1 3 1
5
2 2 1 3 3

output:

1
3
3
1 1 2
2
3 3
3
1 3 1
4
2 1 3 3

result:

ok 10 lines

Test #2:

score: 0
Accepted
time: 4ms
memory: 3672kb

input:

2000
4
2 4 4 1
1
1
3
2 3 2
4
4 4 3 1
1
1
2
3 2
4
1 3 2 1
3
4 1 1
2
4 2
4
2 3 1 2
3
3 4 3
4
1 2 2 1
2
1 1
4
1 4 2 4
2
1 3
4
4 2 4 2
5
2 4 1 4 3
4
3 4 4 3
3
1 4 4
2
1 1
5
2 1 3 2 3
4
3 2 3 4
2
1 2
1
2
4
4 1 3 2
2
1 2
4
4 2 4 4
1
3
2
2 4
1
1
1
1
1
2
4
4 4 4 3
1
1
1
1
1
4
4
1 3 2 1
2
2 1
5
3 1 1 1 1
5
4...

output:

3
2 4 4
1
1
2
2 3
2
4 3
1
1
1
3
3
1 3 2
1
4
1
4
2
2 3
2
3 4
3
1 2 2
1
1
4
1 4 2 4
2
1 3
1
4
2
2 4
3
3 4 4
3
1 4 4
1
1
1
2
1
3
2
1 2
1
2
1
4
2
1 2
1
4
1
3
2
2 4
1
1
1
1
1
2
2
4 4
1
1
1
1
1
4
3
1 3 2
1
2
1
3
1
4
2
2 4
2
1 4
1
3
1
3
1
3
1
3
2
1 3
1
3
1
3
2
2 4
3
3 4 4
1
1
1
3
2
2 4
1
4
2
1 4
1
2
1
3
1
...

result:

ok 4000 lines

Test #3:

score: 0
Accepted
time: 5ms
memory: 3652kb

input:

1000
9
2 4 5 1 3 3 5 3 1
9
1 3 5 1 1 5 3 5 1
10
3 3 3 1 1 5 2 2 5 2
10
4 2 2 2 1 1 4 4 1 3
9
5 1 3 4 5 5 5 1 3
9
3 5 1 2 5 4 5 4 2
9
1 3 4 4 4 5 4 2 1
7
1 3 4 4 4 3 4
7
2 1 3 3 4 2 1
6
3 2 1 3 3 1
7
3 2 2 4 4 3 2
8
2 1 5 3 4 1 4 1
6
3 2 4 5 1 1
9
3 3 3 4 3 4 2 2 4
10
5 3 2 3 5 5 3 1 5 4
10
4 3 2 1 2...

output:

3
2 4 5
3
1 3 5
2
3 3
1
4
1
5
2
3 5
8
1 3 4 4 4 5 4 2
7
1 3 4 4 4 3 4
1
2
1
3
1
3
1
2
1
3
6
3 3 3 4 3 4
1
5
1
4
9
1 1 2 3 4 3 4 3 4
2
2 5
5
2 2 3 5 4
8
1 2 2 5 4 3 1 5
1
5
2
5 3
8
3 1 3 4 3 4 4 2
1
5
10
1 2 3 5 5 5 4 5 2 2
5
4 4 4 4 5
7
3 5 3 1 4 3 5
1
5
4
1 3 3 2
1
3
1
5
5
1 5 5 4 2
9
1 4 5 5 5 4 5...

result:

ok 2000 lines

Test #4:

score: 0
Accepted
time: 6ms
memory: 3616kb

input:

1000
7
1 2 2 1 2 2 2
9
1 2 2 1 2 2 1 2 2
8
2 2 2 2 2 1 2 2
9
2 2 1 1 1 2 1 2 2
6
1 2 2 2 1 2
10
1 2 1 1 1 1 2 1 2 1
10
1 2 2 1 1 2 2 2 1 1
6
1 2 2 1 2 1
9
2 2 2 1 1 2 2 1 1
7
2 2 1 2 1 2 2
8
2 2 2 2 2 2 2 1
10
2 1 2 1 2 2 1 1 1 2
7
1 1 2 2 1 1 2
6
1 2 1 2 2 2
8
1 1 2 2 2 1 2 1
8
2 1 2 2 2 1 1 1
7
1 ...

output:

7
1 2 2 1 2 2 2
6
1 2 2 1 2 2
3
2 2 2
8
2 1 1 1 2 1 2 2
4
1 2 2 2
2
1 2
3
1 2 2
3
1 2 2
2
2 2
6
2 1 2 1 2 2
4
2 2 2 2
1
2
4
1 1 2 2
6
1 2 1 2 2 2
7
1 1 2 2 2 1 2
1
2
7
1 1 1 2 2 1 2
2
2 2
1
2
1
2
1
2
1
2
1
2
3
2 2 2
1
2
3
1 1 2
2
2 2
1
2
4
2 1 2 1
1
2
3
2 2 2
9
2 1 1 1 1 1 1 2 2
10
1 1 1 1 2 1 2 2 1...

result:

ok 2000 lines

Test #5:

score: 0
Accepted
time: 3ms
memory: 3620kb

input:

1100
6
65951 4305 32213 48341 62909 20064
7
4105 96990 75309 35760 67452 84892 54508
5
92708 37969 36767 15623 19886
7
71620 51223 32408 68118 73815 44727 41662
3
36615 71255 4727
3
70923 74293 91999
4
92750 8864 6631 85697
7
4376 69353 72191 789 36678 62216 68678
7
81295 55622 73958 81576 65407 263...

output:

1
65951
7
4105 96990 75309 35760 67452 84892 54508
1
92708
1
71620
2
36615 71255
3
70923 74293 91999
1
92750
3
4376 69353 72191
1
81295
1
93323
1
41017
1
59469
1
83956
2
60808 95491
5
17109 92279 53296 24910 95927
1
70886
6
10239 46424 37215 78348 77525 30513
7
5399 92737 77458 95051 26452 35801 726...

result:

ok 2200 lines

Test #6:

score: 0
Accepted
time: 4ms
memory: 3608kb

input:

1100
5
45415 69994 53502 47407 94453
7
60364 97249 65245 75400 62194 70479 65513
4
52800 24348 95070 27952
5
13216 90384 13299 97784 75320
6
33241 13473 85819 91225 17405 24972
4
79990 5736 68893 59433
6
59378 80219 16895 12312 24912 58269
4
30380 86065 50786 53756
8
50186 50733 17641 5905 66837 194...

output:

5
45415 69994 53502 47407 94453
7
60364 97249 65245 75400 62194 70479 65513
1
52800
5
13216 90384 13299 97784 75320
1
33241
1
79990
2
59378 80219
4
30380 86065 50786 53756
2
50186 50733
1
72648
1
29611
1
96552
6
24982 80140 41216 34415 89122 60945
5
30277 79642 77827 71635 63559
1
98291
1
61717
1
33...

result:

ok 2200 lines

Test #7:

score: 0
Accepted
time: 6ms
memory: 3932kb

input:

10
997
7867 57800 43811 6246 36043 50835 76960 18090 88671 72392 59209 83518 94615 88200 22859 6141 5415 75625 12354 86072 51865 8020 63075 72082 25129 41896 31668 80194 65607 71157 1359 8372 58520 3714 26371 41352 96182 20456 50227 49202 38187 44149 85749 2584 57050 62474 63411 73528 9942 63581 342...

output:

3
7867 57800 43811
1
84217
1
21414
1
43828
297
977 7485 87979 13054 1544 3658 90181 20357 89822 81859 74563 3035 68651 36896 17865 92338 41821 1744 29965 96082 18997 48501 2202 68854 25989 32867 50959 85071 79544 73413 45790 14272 58634 8633 82349 34144 36780 12431 82392 65595 47714 6573 4653 59281 ...

result:

ok 20 lines

Test #8:

score: 0
Accepted
time: 6ms
memory: 3768kb

input:

20
498
51063 59314 96168 74552 94699 75356 30750 41773 19905 22751 82214 17211 76363 29367 6570 73575 83918 72658 38217 76008 40068 97458 4536 99179 35196 89423 69310 90642 29173 73715 7126 97552 42502 59868 84913 142 1273 69469 82481 81450 73900 81053 41584 18163 94543 94678 14359 13422 71656 90327...

output:

6
51063 59314 96168 74552 94699 75356
2
19151 62537
3
53757 89232 57615
5
29113 84684 86393 37996 88215
1
97896
1
57746
3
67543 71460 94938
3
45196 74194 48317
1
87565
1
86823
8
15247 22937 42339 33746 44126 62903 75783 36861
1
27142
1
88546
2
16531 97854
2
64741 90780
1
62602
10
12923 19982 96583 6...

result:

ok 40 lines

Test #9:

score: 0
Accepted
time: 7ms
memory: 3848kb

input:

10
1000
81 27 62 74 79 21 78 76 79 2 39 71 8 53 59 47 77 98 43 27 15 91 91 12 77 40 79 21 49 28 55 77 28 22 80 58 9 85 82 62 99 53 36 17 47 55 35 40 7 85 50 97 1 27 63 45 100 55 65 84 86 67 32 73 53 93 61 67 50 30 35 65 37 56 71 79 87 46 1 6 78 40 40 40 61 68 2 98 54 50 14 16 38 81 52 20 28 12 64 68...

output:

1
81
5
16 26 47 36 84
1
73
1
64
1
76
9
22 57 41 35 79 66 40 90 74
20
10 81 42 51 70 49 27 78 98 76 52 100 41 47 37 38 60 32 28 68
1
62
3
51 66 94
1
16

result:

ok 20 lines

Test #10:

score: 0
Accepted
time: 7ms
memory: 3852kb

input:

10
997
25 12 19 10 10 16 13 22 2 25 25 23 6 14 8 25 16 2 12 14 25 9 15 10 4 15 7 21 8 9 21 12 21 13 4 7 13 2 26 12 22 17 2 9 9 3 16 22 24 19 16 4 9 26 6 16 16 22 22 7 14 11 4 26 26 5 5 13 15 7 4 23 11 6 26 17 5 22 11 14 26 10 2 13 16 11 21 21 11 2 11 15 8 6 26 8 10 8 24 19 6 16 24 23 24 13 16 11 10 ...

output:

1
25
3
9 20 21
1
8
6
6 25 16 11 20 8
1
24
1
21
1
17
3
11 16 15
2
19 20
2
19 23

result:

ok 20 lines

Test #11:

score: 0
Accepted
time: 8ms
memory: 3932kb

input:

10
998
5 1 3 4 3 3 2 2 1 1 1 2 2 3 2 5 4 3 4 4 4 1 2 4 2 4 4 5 1 4 5 1 3 2 3 4 3 5 3 2 2 2 2 3 3 5 3 3 1 2 3 1 2 4 3 5 3 3 3 5 4 3 1 5 3 3 4 3 5 3 3 1 1 4 3 3 4 4 3 5 5 2 4 1 3 5 2 5 3 4 1 1 2 3 1 2 4 5 4 3 1 4 5 5 1 2 5 3 4 4 1 3 5 2 4 5 3 3 3 5 4 5 1 1 2 1 2 3 2 2 5 4 5 1 5 5 1 5 5 3 1 4 3 5 4 2 4...

output:

1
5
14
1 1 5 3 4 2 3 4 3 5 2 2 2 5
1
5
2
2 3
4
1 4 2 4
7
2 2 4 4 4 2 3
1
3
26
5 1 2 3 4 5 2 3 3 1 4 1 2 5 4 5 5 1 2 5 2 1 5 4 1 5
3
2 3 2
1
4

result:

ok 20 lines

Test #12:

score: 0
Accepted
time: 7ms
memory: 3992kb

input:

10
996
2 1 1 2 2 2 2 1 2 2 2 1 2 1 2 2 1 1 2 1 2 1 2 1 1 1 1 2 1 1 2 1 2 2 2 1 2 1 2 2 2 2 2 1 2 1 1 1 2 2 1 1 2 2 2 2 2 2 2 2 2 1 2 1 2 2 1 1 1 2 2 2 2 1 1 1 1 2 1 1 2 2 1 2 2 2 2 1 1 1 1 1 2 2 2 1 1 2 2 2 1 1 1 1 1 2 1 2 2 2 1 2 1 1 1 1 1 1 2 2 2 1 2 2 1 2 1 1 1 1 2 2 1 2 2 2 2 2 1 2 2 2 1 1 2 2 1...

output:

1
2
17
1 1 2 2 1 1 2 1 2 1 2 2 2 1 2 2 2
15
1 1 1 2 2 1 2 2 2 2 2 1 1 2 2
1
2
5
2 2 2 1 2
6
1 1 2 2 2 2
85
1 2 1 1 1 1 1 1 2 1 1 2 2 1 1 2 1 1 1 2 2 2 1 2 2 1 2 2 1 1 2 2 2 2 1 1 1 2 2 1 1 1 2 2 1 2 2 2 1 1 1 1 1 2 2 2 2 2 1 2 2 1 1 1 1 2 2 2 2 1 2 1 1 2 1 2 1 1 2 2 2 2 1 1 2
159
2 2 2 2 1 1 1 1 1 2...

result:

ok 20 lines

Test #13:

score: 0
Accepted
time: 11ms
memory: 4680kb

input:

4
2496
2 1 2 2 1 1 1 1 1 1 2 1 1 1 1 1 2 1 1 2 2 2 2 1 2 2 2 1 2 2 1 2 1 2 2 2 2 2 2 1 2 2 1 1 2 2 1 2 2 2 1 1 1 2 1 1 2 1 1 2 2 1 1 1 1 2 2 2 1 1 2 2 2 1 1 2 1 1 1 2 2 2 2 2 1 1 1 1 1 2 1 1 2 2 2 2 1 1 1 1 2 1 2 2 1 2 1 2 2 1 1 1 1 2 2 1 2 2 2 2 2 2 2 2 2 1 2 2 1 2 1 1 1 2 1 1 1 1 2 1 1 1 1 2 1 1 2...

output:

1
2
3
1 2 2
165
2 1 2 1 1 1 1 1 1 1 2 1 2 1 2 2 1 1 2 2 1 2 2 1 2 2 1 2 2 1 2 1 1 1 2 1 1 2 2 1 2 2 1 1 2 2 2 1 1 2 2 2 1 2 1 2 1 1 1 1 2 2 1 1 2 1 2 1 2 2 1 2 1 1 1 2 1 1 1 2 1 2 1 2 2 2 1 1 1 1 1 1 2 1 2 2 2 1 2 1 1 1 2 2 1 2 1 1 2 2 2 1 1 1 1 2 2 2 2 2 1 1 1 2 2 1 2 2 1 1 2 1 1 1 1 2 2 2 1 2 1 1 ...

result:

ok 8 lines

Test #14:

score: 0
Accepted
time: 8ms
memory: 4232kb

input:

4
2498
4 1 4 4 1 1 1 2 3 1 5 2 1 3 2 2 1 4 5 4 1 2 4 1 5 1 5 5 4 2 4 4 3 5 5 2 5 2 2 1 3 5 4 1 4 4 5 1 3 2 3 1 4 4 1 2 2 4 4 2 5 5 2 4 3 3 1 1 1 4 3 4 2 3 1 2 4 3 2 5 2 4 2 4 3 1 3 2 4 1 4 1 4 2 4 2 1 2 3 3 4 3 1 4 4 4 1 3 5 5 1 2 3 1 1 1 5 2 4 4 1 4 5 4 2 5 4 2 4 2 1 2 2 4 4 2 5 3 5 1 2 2 1 3 3 1 3...

output:

1
4
6
1 3 2 4 2 5
16
1 2 4 2 1 5 4 4 5 3 3 3 1 4 4 2
3
4 4 5

result:

ok 8 lines

Test #15:

score: 0
Accepted
time: 7ms
memory: 4088kb

input:

4
2500
25 16 8 17 13 16 14 14 15 23 20 18 3 18 12 2 1 7 12 12 2 4 19 7 18 26 1 11 18 16 11 17 19 3 4 16 18 9 25 3 23 14 15 8 1 2 15 2 14 26 23 19 3 19 16 22 22 8 24 5 16 21 6 22 4 8 17 10 11 9 11 23 7 18 5 12 5 8 1 8 17 26 16 8 22 9 7 14 24 4 3 10 20 12 23 17 9 10 18 8 8 16 12 1 25 26 14 9 17 16 12 ...

output:

1
25
20
4 5 20 19 14 5 23 5 10 10 23 10 25 26 17 10 23 17 15 24
1
22
3
18 19 25

result:

ok 8 lines

Test #16:

score: 0
Accepted
time: 6ms
memory: 4052kb

input:

4
2499
10131 7369 53764 18817 22200 68311 8149 60362 30172 20980 52993 6535 28733 12314 91330 99229 24047 50675 39589 62369 10426 52578 7629 16829 82010 33210 28815 77137 45215 62821 69973 49392 76299 73854 87516 5983 92567 75831 94421 98009 4013 72308 45191 29933 64623 41582 62251 59966 62063 84722...

output:

1
10131
3
35839 65680 83135
1
79815
2
90356 99907

result:

ok 8 lines

Test #17:

score: 0
Accepted
time: 11ms
memory: 4900kb

input:

2
4997
2 1 1 1 1 2 1 2 1 1 1 2 1 1 1 2 1 1 1 2 1 1 1 1 2 1 1 1 1 1 2 1 1 2 2 1 2 1 1 2 2 2 1 1 2 1 1 2 2 1 1 2 2 1 1 2 2 2 1 2 2 1 1 1 1 2 2 1 1 2 1 2 2 2 1 1 1 2 2 1 2 1 1 1 2 2 1 1 2 1 2 2 2 1 1 1 1 1 2 1 1 1 1 1 2 2 2 2 1 2 2 2 2 1 1 2 2 1 2 2 1 1 1 2 2 1 1 2 2 1 1 2 1 1 1 1 1 1 1 2 2 1 1 1 2 2 2...

output:

1
2
3
2 2 2

result:

ok 4 lines

Test #18:

score: 0
Accepted
time: 9ms
memory: 4740kb

input:

2
4999
2 1 3 1 2 3 5 3 1 3 5 2 1 5 1 5 3 4 4 4 3 2 2 1 5 3 5 2 4 4 3 1 4 2 5 5 5 5 2 2 3 4 2 2 5 1 3 3 1 2 3 5 5 5 5 2 5 4 5 1 1 3 3 1 2 5 5 3 2 5 2 5 2 1 1 2 2 5 4 3 2 3 5 3 5 3 5 1 1 5 2 3 3 1 5 1 5 2 1 3 4 4 3 1 4 5 1 1 4 3 5 4 4 2 2 4 1 3 3 4 3 3 2 2 5 2 3 1 3 3 4 4 4 3 3 2 2 5 1 1 5 3 5 2 2 4 1...

output:

1
2
3
2 3 3

result:

ok 4 lines

Test #19:

score: 0
Accepted
time: 7ms
memory: 4648kb

input:

2
4996
3 11 1 12 21 25 20 3 14 24 16 4 7 13 4 22 12 12 17 4 10 23 20 23 8 1 15 25 18 23 25 25 26 19 18 6 5 1 25 5 22 26 10 12 16 18 8 20 16 22 10 17 11 10 14 25 21 18 24 24 22 14 3 8 2 4 20 14 24 16 19 26 19 6 11 23 16 11 8 3 1 21 10 22 10 23 18 10 17 22 14 10 2 24 23 2 13 24 13 26 7 24 8 18 1 14 3 ...

output:

2
3 11
5
13 13 21 19 16

result:

ok 4 lines

Test #20:

score: 0
Accepted
time: 7ms
memory: 4520kb

input:

2
4998
458 1059 2246 1729 3608 2021 1256 2524 632 4070 1619 959 2116 1295 4984 2135 3846 4925 534 4739 3561 4491 4849 4438 4944 3358 917 2873 2645 4607 1159 198 2340 933 717 4910 2845 3488 2345 3021 1381 3887 3658 1704 5 2563 818 1958 4474 1786 1457 1028 347 4893 3440 1079 4087 1482 3255 2055 892 41...

output:

31
458 1059 2246 1729 3608 2021 1256 2524 632 4070 1619 959 2116 1295 4984 2135 3846 4925 534 4739 3561 4491 4849 4438 4944 3358 917 2873 2645 4607 1159
2
2440 2503

result:

ok 4 lines

Test #21:

score: 0
Accepted
time: 7ms
memory: 4576kb

input:

2
4999
79217 55222 9324 98715 83920 52160 82116 89821 64862 22617 28820 66046 29843 18831 12782 73434 61786 94857 89304 39646 72722 66367 5002 71502 6832 17981 34452 69313 78651 84004 43701 22560 26991 27017 83781 42731 76059 50325 73132 18227 77475 20163 95592 7361 58750 63204 28396 98990 27896 282...

output:

1
79217
1
70945

result:

ok 4 lines

Test #22:

score: 0
Accepted
time: 10ms
memory: 4952kb

input:

2
4998
3 2 2 3 2 1 3 1 3 2 1 2 1 1 2 2 2 2 1 2 1 2 2 2 3 1 3 2 3 3 1 1 1 3 2 3 1 2 3 3 3 2 3 3 1 1 1 1 2 2 3 3 2 2 2 3 2 3 2 1 1 1 3 2 3 3 3 2 1 3 3 2 3 1 1 3 2 2 2 2 1 3 2 3 3 1 1 1 1 3 3 3 1 3 2 2 2 2 3 1 2 1 2 1 2 1 3 1 2 2 2 2 3 3 1 3 1 3 2 3 1 3 2 1 2 1 2 3 1 3 3 3 1 3 3 3 1 1 2 2 3 3 1 2 1 2 2...

output:

1
3
2
2 2

result:

ok 4 lines

Test #23:

score: 0
Accepted
time: 3ms
memory: 4596kb

input:

2
4998
30 97 25 9 4 14 21 61 30 84 40 31 61 43 59 71 93 27 26 66 37 71 1 11 25 81 69 79 22 40 100 29 18 49 6 75 45 98 16 92 61 2 33 95 39 43 84 42 19 2 20 65 84 23 20 31 94 58 19 53 14 27 1 42 50 43 4 43 82 37 99 85 76 74 55 26 73 81 57 20 2 76 22 38 68 9 7 29 52 73 1 21 55 76 26 73 31 4 78 82 52 30...

output:

2
30 97
6
24 39 83 90 27 87

result:

ok 4 lines

Test #24:

score: 0
Accepted
time: 8ms
memory: 19224kb

input:

2
5000
99981 99981 99835 99835 99774 99774 99743 99743 99740 99740 99622 99622 99567 99567 99553 99553 99539 99539 99518 99518 99470 99470 99466 99466 99456 99456 99438 99438 99418 99418 99351 99351 99313 99313 99312 99312 99278 99278 99236 99236 99234 99234 99224 99224 99215 99215 99208 99208 99176...

output:

2500
99981 99835 99774 99743 99740 99622 99567 99553 99539 99518 99470 99466 99456 99438 99418 99351 99313 99312 99278 99236 99234 99224 99215 99208 99176 99153 99150 99097 98946 98932 98910 98817 98752 98712 98664 98639 98558 98556 98534 98506 98463 98442 98359 98327 98298 98263 98233 98160 98134 9...

result:

ok 4 lines

Test #25:

score: 0
Accepted
time: 10ms
memory: 19388kb

input:

2
5000
2999 2999 2997 2997 2997 2997 2997 2997 2994 2994 2994 2994 2992 2992 2991 2991 2990 2990 2983 2983 2983 2983 2981 2981 2979 2979 2978 2978 2977 2977 2976 2976 2975 2975 2974 2974 2974 2974 2973 2973 2973 2973 2972 2972 2972 2972 2971 2971 2971 2971 2970 2970 2967 2967 2966 2966 2965 2965 296...

output:

2500
2999 2997 2997 2997 2994 2994 2992 2991 2990 2983 2983 2981 2979 2978 2977 2976 2975 2974 2974 2973 2973 2972 2972 2971 2971 2970 2967 2966 2965 2965 2964 2963 2962 2961 2956 2955 2955 2954 2954 2953 2952 2950 2950 2947 2947 2946 2946 2944 2943 2942 2941 2939 2937 2937 2935 2935 2934 2932 2931 ...

result:

ok 4 lines

Test #26:

score: 0
Accepted
time: 69ms
memory: 31556kb

input:

2
5000
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

output:

2500
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

result:

ok 4 lines

Extra Test:

score: 0
Extra Test Passed