QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#699529 | #9538. Closest Derangement | ucup-team896# | AC ✓ | 2432ms | 171148kb | C++23 | 16.9kb | 2024-11-02 09:38:46 | 2024-11-02 09:38:47 |
Judging History
answer
/* _ _ _ _ __ __ __
/ \ _ _ | |_ | |__ ___ _ __ _ ___ _ __ ___ | | __ / /_ / /_ / /_
/ _ \ | | | | | __| | '_ \ / _ \ | '__| (_) / __| | '_ ` _ \ | |/ / | '_ \ | '_ \ | '_ \
/ ___ \ | |_| | | |_ | | | | | (_) | | | _ | (__ | | | | | | | < | (_) | | (_) | | (_) |
/_/ \_\ \__,_| \__| |_| |_| \___/ |_| (_) \___| |_| |_| |_| |_|\_\ \___/ \___/ \___/
[Created Time: 2024-11-02 08:45:12]
[Last Modified Time: 2024-11-02 09:38:19] */
#ifdef LOCAL
#include<bits/stdc++.h>
#include"debug.h"
#else
#pragma GCC optimize("Ofast", "unroll-loops")
#include<bits/stdc++.h>
#define D(...) ((void)0)
#endif
using namespace std; using ll = long long;
#define For(i, j, k) for ( int i = (j) ; i <= (k) ; i++ )
#define Fol(i, j, k) for ( int i = (j) ; i >= (k) ; i-- )
namespace FastIO
{
#define USE_FastIO
// ------------------------------
// #define DISABLE_MMAP
// ------------------------------
#if ( defined(LOCAL) || defined(_WIN32) ) && !defined(DISABLE_MMAP)
#define DISABLE_MMAP
#endif
#ifdef LOCAL
inline void _chk_i() {}
inline char _gc_nochk() { return getchar(); }
inline char _gc() { return getchar(); }
inline void _chk_o() {}
inline void _pc_nochk(char c) { putchar(c); }
inline void _pc(char c) { putchar(c); }
template < int n > inline void _pnc_nochk(const char *c) { for ( int i = 0 ; i < n ; i++ ) putchar(c[i]); }
#else
#ifdef DISABLE_MMAP
inline constexpr int _READ_SIZE = 1 << 18; inline static char _read_buffer[_READ_SIZE + 40], *_read_ptr = nullptr, *_read_ptr_end = nullptr; static inline bool _eof = false;
inline void _chk_i() { if ( __builtin_expect(!_eof, true) && __builtin_expect(_read_ptr_end - _read_ptr < 40, false) ) { int sz = _read_ptr_end - _read_ptr; if ( sz ) memcpy(_read_buffer, _read_ptr, sz); char *beg = _read_buffer + sz; _read_ptr = _read_buffer, _read_ptr_end = beg + fread(beg, 1, _READ_SIZE, stdin); if ( __builtin_expect(_read_ptr_end != beg + _READ_SIZE, false) ) _eof = true, *_read_ptr_end = EOF; } }
inline char _gc_nochk() { return __builtin_expect(_eof && _read_ptr == _read_ptr_end, false) ? EOF : *_read_ptr++; }
inline char _gc() { _chk_i(); return _gc_nochk(); }
#else
#include<sys/mman.h>
#include<sys/stat.h>
inline static char *_read_ptr = (char *)mmap(nullptr, [] { struct stat s; return fstat(0, &s), s.st_size; } (), 1, 2, 0, 0);
inline void _chk_i() {}
inline char _gc_nochk() { return *_read_ptr++; }
inline char _gc() { return *_read_ptr++; }
#endif
inline constexpr int _WRITE_SIZE = 1 << 18; inline static char _write_buffer[_WRITE_SIZE + 40], *_write_ptr = _write_buffer;
inline void _chk_o() { if ( __builtin_expect(_write_ptr - _write_buffer > _WRITE_SIZE, false) ) fwrite(_write_buffer, 1, _write_ptr - _write_buffer, stdout), _write_ptr = _write_buffer; }
inline void _pc_nochk(char c) { *_write_ptr++ = c; }
inline void _pc(char c) { *_write_ptr++ = c, _chk_o(); }
template < int n > inline void _pnc_nochk(const char *c) { memcpy(_write_ptr, c, n), _write_ptr += n; }
inline struct _auto_flush { inline ~_auto_flush() { fwrite(_write_buffer, 1, _write_ptr - _write_buffer, stdout); } } _auto_flush;
#endif
#define println println_ // don't use C++23 std::println
template < class T > inline constexpr bool _is_signed = numeric_limits < T >::is_signed;
template < class T > inline constexpr bool _is_unsigned = numeric_limits < T >::is_integer && !_is_signed < T >;
#if __SIZEOF_LONG__ == 64
template <> inline constexpr bool _is_signed < __int128 > = true;
template <> inline constexpr bool _is_unsigned < __uint128_t > = true;
#endif
inline bool _isgraph(char c) { return c >= 33; }
inline bool _isdigit(char c) { return 48 <= c && c <= 57; } // or faster, remove c <= 57
constexpr struct _table {
#ifndef LOCAL
int i[65536];
#endif
char o[40000]; constexpr _table() :
#ifndef LOCAL
i{},
#endif
o{} {
#ifndef LOCAL
for ( int x = 0 ; x < 65536 ; x++ ) i[x] = -1; for ( int x = 0 ; x <= 9 ; x++ ) for ( int y = 0 ; y <= 9 ; y++ ) i[x + y * 256 + 12336] = x * 10 + y;
#endif
for ( int x = 0 ; x < 10000 ; x++ ) for ( int y = 3, z = x ; ~y ; y-- ) o[x * 4 + y] = z % 10 + 48, z /= 10; } } _table;
template < class T, int digit > inline constexpr T _pw10 = 10 * _pw10 < T, digit - 1 >;
template < class T > inline constexpr T _pw10 < T, 0 > = 1;
inline void read(char &c) { do c = _gc(); while ( !_isgraph(c) ); }
inline void read_cstr(char *s) { char c = _gc(); while ( !_isgraph(c) ) c = _gc(); while ( _isgraph(c) ) *s++ = c, c = _gc(); *s = 0; }
inline void read(string &s) { char c = _gc(); s.clear(); while ( !_isgraph(c) ) c = _gc(); while ( _isgraph(c) ) s.push_back(c), c = _gc(); }
template < class T, bool neg >
#ifndef LOCAL
__attribute__((no_sanitize("undefined")))
#endif
inline void _read_int_suf(T &x) { _chk_i(); char c; while
#ifndef LOCAL
( ~_table.i[*reinterpret_cast < unsigned short *& >(_read_ptr)] ) if constexpr ( neg ) x = x * 100 - _table.i[*reinterpret_cast < unsigned short *& >(_read_ptr)++]; else x = x * 100 + _table.i[*reinterpret_cast < unsigned short *& >(_read_ptr)++]; if
#endif
( _isdigit(c = _gc_nochk()) ) if constexpr ( neg ) x = x * 10 - ( c & 15 ); else x = x * 10 + ( c & 15 ); }
template < class T, enable_if_t < _is_signed < T >, int > = 0 > inline void read(T &x) { char c; while ( !_isdigit(c = _gc()) ) if ( c == 45 ) { _read_int_suf < T, true >(x = -( _gc_nochk() & 15 )); return; } _read_int_suf < T, false >(x = c & 15); }
template < class T, enable_if_t < _is_unsigned < T >, int > = 0 > inline void read(T &x) { char c; while ( !_isdigit(c = _gc()) ); _read_int_suf < T, false >(x = c & 15); }
inline void write(bool x) { _pc(x | 48); }
inline void write(char c) { _pc(c); }
inline void write_cstr(const char *s) { while ( *s ) _pc(*s++); }
inline void write(const string &s) { for ( char c : s ) _pc(c); }
template < class T, bool neg, int digit > inline void _write_int_suf(T x) { if constexpr ( digit == 4 ) _pnc_nochk < 4 >(_table.o + ( neg ? -x : x ) * 4); else _write_int_suf < T, neg, digit / 2 >(x / _pw10 < T, digit / 2 >), _write_int_suf < T, neg, digit / 2 >(x % _pw10 < T, digit / 2 >); }
template < class T, bool neg, int digit > inline void _write_int_pre(T x) { if constexpr ( digit <= 4 ) if ( digit >= 3 && ( neg ? x <= -100 : x >= 100 ) ) if ( digit >= 4 && ( neg ? x <= -1000 : x >= 1000 ) ) _pnc_nochk < 4 >(_table.o + ( neg ? -x : x ) * 4); else _pnc_nochk < 3 >(_table.o + ( neg ? -x : x ) * 4 + 1); else if ( digit >= 2 && ( neg ? x <= -10 : x >= 10 ) ) _pnc_nochk < 2 >(_table.o + ( neg ? -x : x ) * 4 + 2); else _pc_nochk(( neg ? -x : x ) | 48); else { constexpr int cur = 1 << __lg(digit - 1); if ( neg ? x <= -_pw10 < T, cur > : x >= _pw10 < T, cur > ) _write_int_pre < T, neg, digit - cur >(x / _pw10 < T, cur >), _write_int_suf < T, neg, cur >(x % _pw10 < T, cur >); else _write_int_pre < T, neg, cur >(x); } }
template < class T, enable_if_t < _is_signed < T >, int > = 0 > inline void write(T x) { if ( x >= 0 ) _write_int_pre < T, false, numeric_limits < T >::digits10 + 1 >(x); else _pc_nochk(45), _write_int_pre < T, true, numeric_limits < T >::digits10 + 1 >(x); _chk_o(); }
template < class T, enable_if_t < _is_unsigned < T >, int > = 0 > inline void write(T x) { _write_int_pre < T, false, numeric_limits < T >::digits10 + 1 >(x), _chk_o(); }
template < size_t N, class ...T > inline void _read_tuple(tuple < T... > &x) { read(get < N >(x)); if constexpr ( N + 1 != sizeof...(T) ) _read_tuple < N + 1, T... >(x); }
template < size_t N, class ...T > inline void _write_tuple(const tuple < T... > &x) { write(get < N >(x)); if constexpr ( N + 1 != sizeof...(T) ) _pc(32), _write_tuple < N + 1, T... >(x); }
template < class ...T > inline void read(tuple < T... > &x) { _read_tuple < 0, T... >(x); }
template < class ...T > inline void write(const tuple < T... > &x) { _write_tuple < 0, T... >(x); }
template < class T1, class T2 > inline void read(pair < T1, T2 > &x) { read(x.first), read(x.second); }
template < class T1, class T2 > inline void write(const pair < T1, T2 > &x) { write(x.first), _pc(32), write(x.second); }
template < class T > inline auto read(T &x) -> decltype(x.read(), void()) { x.read(); }
template < class T > inline auto write(const T &x) -> decltype(x.write(), void()) { x.write(); }
template < class T1, class ...T2 > inline void read(T1 &x, T2 &...y) { read(x), read(y...); }
template < class ...T > inline void read_cstr(char *x, T *...y) { read_cstr(x), read_cstr(y...); }
template < class T1, class ...T2 > inline void write(const T1 &x, const T2 &...y) { write(x), write(y...); }
template < class ...T > inline void write_cstr(const char *x, const T *...y) { write_cstr(x), write_cstr(y...); }
template < class T > inline void print(const T &x) { write(x); }
inline void print_cstr(const char *x) { write_cstr(x); }
template < class T1, class ...T2 > inline void print(const T1 &x, const T2 &...y) { write(x), _pc(32), print(y...); }
template < class ...T > inline void print_cstr(const char *x, const T *...y) { write_cstr(x), _pc(32), print_cstr(y...); }
inline void println() { _pc(10); }
inline void println_cstr() { _pc(10); }
template < class ...T > inline void println(const T &...x) { print(x...), _pc(10); }
template < class ...T > inline void println_cstr(const T *...x) { print_cstr(x...), _pc(10); }
} using FastIO::read, FastIO::read_cstr, FastIO::write, FastIO::write_cstr, FastIO::println, FastIO::println_cstr;
template < auto P_ > class MontgomeryModInt
{
using S = decltype(P_); static_assert(is_same_v < S, int > || is_same_v < S, long > || is_same_v < S, long long >);
static_assert(P_ & 1 && 0 < P_ && P_ < ( (S)1 << ( sizeof(S) * 8 - 2 ) ));
using U = conditional_t < is_same_v < S, int >, unsigned, unsigned long long >; using D = conditional_t < is_same_v < S, int >, unsigned long long, __uint128_t >;
inline constexpr static U uinv(U x) { U y = x; for ( int i = is_same_v < S, int > ? 4 : 5 ; i-- ; ) y *= 2 - x * y; return y; }
constexpr static U P = P_, P2 = P << 1, R = -uinv(P), R2 = -(D)P % P; static_assert(P * R == -1);
inline constexpr static U reduce(D x) { return ( x + (U)x * R * (D)P ) >> ( sizeof(U) * 8 ); }
inline constexpr MontgomeryModInt(U x, int) : v(x) {} U v;
public:
inline constexpr static S mod() { return P; }
inline constexpr MontgomeryModInt() : v(0) {}
inline constexpr MontgomeryModInt(const MontgomeryModInt &x) : v(x.v) {}
template < class T, enable_if_t < numeric_limits < T >::is_integer, int > = 0 > inline constexpr MontgomeryModInt(T x) : v(reduce((D)R2 * ( numeric_limits < T >::is_signed && x < 0 ? ( ( x + P < 0 ) && ( x %= P ), x + P ) : ( ( sizeof(T) > sizeof(U) && x >= (T)1 << sizeof(U) ) && ( x %= P ), x ) ))) {}
inline constexpr S val()const { U x = reduce(v); return ( x - P ) >> ( sizeof(U) * 8 - 1 ) ? x : x - P; }
template < class T, enable_if_t < numeric_limits < T >::is_integer, int > = 0 > explicit inline constexpr operator T()const { return val(); }
inline constexpr friend bool operator==(const MontgomeryModInt &x, const MontgomeryModInt &y) { return x.val() == y.val(); }
inline constexpr friend bool operator!=(const MontgomeryModInt &x, const MontgomeryModInt &y) { return x.val() != y.val(); }
inline constexpr MontgomeryModInt &operator=(const MontgomeryModInt &x) & { v = x.v; return *this; }
inline constexpr MontgomeryModInt &operator++() & { return *this += 1; }
inline constexpr MontgomeryModInt operator++(int) & { MontgomeryModInt x = *this; *this += 1; return x; }
inline constexpr MontgomeryModInt &operator--() & { return *this -= 1; }
inline constexpr MontgomeryModInt operator--(int) & { MontgomeryModInt x = *this; *this -= 1; return x; }
inline constexpr MontgomeryModInt operator-()const { return MontgomeryModInt(v ? P2 - v : 0, 0); }
inline constexpr MontgomeryModInt &operator+=(const MontgomeryModInt &x) & { v += x.v, ( v - P2 ) >> ( sizeof(U) * 8 - 1 ) || ( v -= P2 ); return *this; }
inline constexpr MontgomeryModInt &operator-=(const MontgomeryModInt &x) & { v -= x.v, v >> ( sizeof(U) * 8 - 1 ) && ( v += P2 ); return *this; }
inline constexpr MontgomeryModInt &operator*=(const MontgomeryModInt &x) & { v = reduce((D)v * x.v); return *this; }
inline constexpr MontgomeryModInt &operator/=(const MontgomeryModInt &x) & { return *this *= x.inv(); }
inline constexpr friend MontgomeryModInt operator+(MontgomeryModInt x, const MontgomeryModInt &y) { return x += y; }
inline constexpr friend MontgomeryModInt operator-(MontgomeryModInt x, const MontgomeryModInt &y) { return x -= y; }
inline constexpr friend MontgomeryModInt operator*(MontgomeryModInt x, const MontgomeryModInt &y) { return x *= y; }
inline constexpr friend MontgomeryModInt operator/(MontgomeryModInt x, const MontgomeryModInt &y) { return x /= y; }
template < class T, enable_if_t < numeric_limits < T >::is_integer, int > = 0 > inline constexpr MontgomeryModInt qpow(T y)const { MontgomeryModInt x = *this, z = 1; while ( y ) { if ( y & 1 ) z *= x; if ( y >>= 1 ) x *= x; } return z; }
template < class T, enable_if_t < numeric_limits < T >::is_integer, int > = 0 > inline constexpr friend MontgomeryModInt qpow(const MontgomeryModInt &x, T y) { return x.qpow(y); }
inline constexpr MontgomeryModInt inv()const { return qpow(P - 2); }
inline constexpr friend MontgomeryModInt inv(const MontgomeryModInt &x) { return x.inv(); }
inline friend istream &operator>>(istream &is, MontgomeryModInt &x) { S y; is >> y, x = y; return is; }
inline friend ostream &operator<<(ostream &os, const MontgomeryModInt &x) { return os << x.val(); }
#ifdef USE_FastIO
inline void read() & { S x; ::read(x), *this = x; }
inline void write()const { ::write(val()); }
#endif
}; using MI = MontgomeryModInt < 1145141919810000037 >; // 1000000007 1145141919810000037
mt19937 rnd(chrono::system_clock::now().time_since_epoch().count());
template < class T > inline T R(T l, T r) { return uniform_int_distribution < T >(l, r)(rnd); }
const MI B = MI::mod() / 2 + R(-2333333333ll, 2333333333ll); MI pw[200009];
inline void init_pw(int x) { *pw = 1; For(i, 1, x) pw[i] = pw[i - 1] * B; }
template < class IT > inline void calc_hash(IT s, int n, MI *h)
{ *h = 0; For(i, 1, n) h[i] = h[i - 1] * B + s[i]; }
template < class IT > inline MI calc_hash(IT s, int n)
{ MI h = 0; For(i, 1, n) h = h * B + s[i]; return h; }
inline MI qry(MI *h, int l, int r) { return h[r] - h[l - 1] * pw[r - l + 1]; }
namespace ST
{
struct node
{
int lc, rc; MI v;
} t[10000009]; int cnt;
inline int &lc(int p) { return t[p].lc; }
inline int &rc(int p) { return t[p].rc; }
inline int md(int l, int r) { return ( l + r ) >> 1; }
inline void clr() { while ( cnt ) t[cnt].v = lc(cnt) = rc(cnt) = 0, cnt--; }
inline void add(int &p, int l, int r, int pos, MI v)
{
t[++cnt] = t[p], p = cnt, t[p].v += v;
if ( l != r ) pos <= md(l, r) ? add(lc(p), l, md(l, r), pos, v)
: add(rc(p), md(l, r) + 1, r, pos, v);
}
inline MI qry(int p, int l, int r, int lp, int rp)
{
if ( !p || l > rp || r < lp ) return 0;
if ( lp <= l && r <= rp ) return t[p].v;
return qry(lc(p), l, md(l, r), lp, rp) + qry(rc(p), md(l, r) + 1, r, lp, rp);
}
}
using E = tuple < int, int, int >;
int n, k, o, a[200009], pos[200009], rtl[200009], rtr[200009]; E qwq[200009];
inline int f(int x) { return x & 1 ? x + 1 : x - 1; }
inline int g(int x) { return x & 1 ? x - 1 : x + 1; }
inline int qry(const E &e, int p)
{
int w = max({ get<0>(e), get<1>(e), get<2>(e) });
return a[p] < w - 2 ? f(a[p]) : a[p] > w ? g(a[p]) :
a[p] == w - 2 ? get<0>(e) : a[p] == w - 1 ? get<1>(e) : get<2>(e);
}
inline MI qryh(const E &e, int p)
{
int w = max({ get<0>(e), get<1>(e), get<2>(e) });
MI z = ST::qry(rtl[w - 3], 1, n, 1, p) + ST::qry(rtr[w + 1], 1, n, 1, p);
if ( pos[w - 2] <= p ) z += get<0>(e) * pw[pos[w - 2]];
if ( pos[w - 1] <= p ) z += get<1>(e) * pw[pos[w - 1]];
if ( pos[w ] <= p ) z += get<2>(e) * pw[pos[w ]];
return z;
}
inline void work()
{
read(n, k);
For(i, 1, n) read(a[i]);
if ( n & 1 )
{
if ( k > ( o = n - 1 ) ) { println(-1); return; }
For(i, 1, n) pos[a[i]] = i;
ST::clr(), rtl[0] = rtr[n + 1] = 0, init_pw(n);
For(i, 1, n - 1) ST::add(rtl[i] = rtl[i - 1], 1, n, pos[i], f(i) * pw[pos[i]]);
Fol(i, n, 2) ST::add(rtr[i] = rtr[i + 1], 1, n, pos[i], g(i) * pw[pos[i]]);
for ( int i = 3, j = 0 ; i <= n ; i += 2 )
qwq[++j] = E(i - 1, i, i - 2), qwq[++j] = E(i, i - 2, i - 1);
nth_element(qwq + 1, qwq + k, qwq + o + 1, [&](const E &x, const E &y) {
int l = 0, r = n, md;
while ( l < r ) md = ( l + r + 1 ) >> 1, qryh(x, md) == qryh(y, md) ? l = md : r = md - 1;
return assert(l != n), qry(x, l + 1) < qry(y, l + 1);
});
For(i, 1, n) write(qry(qwq[k], i), i == n ? '\n' : ' ');
}
else
{
if ( k > 1 ) { println(-1); return; }
For(i, 1, n) write(f(a[i]), i == n ? '\n' : ' ');
}
}
int main() { int t; read(t); For(tt, 1, t) work(); return 0; }
// 想上GM捏 想上GM捏 想上GM捏 想上GM捏 想上GM捏
// 伊娜可爱捏 伊娜贴贴捏
这程序好像有点Bug,我给组数据试试?
详细
Test #1:
score: 100
Accepted
time: 8ms
memory: 165632kb
input:
2 2 2 2 1 3 2 1 2 3
output:
-1 3 1 2
result:
ok 2 lines
Test #2:
score: 0
Accepted
time: 7ms
memory: 165564kb
input:
50 6 1 4 2 6 3 5 1 8 1 6 2 8 7 3 4 1 5 3 298728530 2 3 1 4 610615077 2 4 3 1 4 2 4 2 3 1 7 152065238 4 1 3 5 7 6 2 6 844435075 2 6 4 5 1 3 4 544008000 3 2 4 1 9 379783780 5 9 3 8 4 2 1 7 6 5 139426002 2 4 5 3 1 2 1 1 2 2 1 1 2 3 1 3 1 2 4 2 2 4 1 3 4 1 3 2 4 1 5 4 2 4 1 5 3 3 1 1 2 3 6 805720317 5 6...
output:
3 1 5 4 6 2 5 1 7 8 4 3 2 6 -1 -1 -1 -1 -1 -1 -1 -1 2 1 2 1 1 2 3 -1 4 1 3 2 3 5 2 4 1 2 3 1 -1 -1 -1 2 1 -1 -1 2 4 3 1 -1 -1 -1 -1 -1 5 3 7 8 6 4 1 2 1 3 2 -1 3 7 9 5 8 1 4 2 6 -1 1 2 -1 -1 -1 8 5 3 2 4 7 1 6 -1 -1 5 1 6 7 4 3 2 -1 5 2 4 1 6 3 7 1 2 -1 2 1 -1 4 1 3 2 5 -1
result:
ok 50 lines
Test #3:
score: 0
Accepted
time: 8ms
memory: 163712kb
input:
100 7 3 6 4 3 5 1 2 7 7 2 7 6 5 1 3 4 2 3 579339385 3 1 2 3 244980876 1 2 3 2 1 2 1 6 184906010 1 4 2 6 5 3 6 908625780 3 2 6 4 5 1 4 223847761 2 3 1 4 7 4078777 1 3 4 2 6 5 7 5 955859204 1 3 5 4 2 5 3 4 5 3 2 1 7 6 1 7 4 3 6 2 5 6 2 4 2 3 1 6 5 2 1 1 2 7 6 5 4 6 7 2 1 3 2 2 2 1 3 2 2 3 1 6 38861221...
output:
7 3 5 4 2 1 6 6 5 7 2 4 3 1 -1 -1 1 2 -1 -1 -1 -1 -1 5 4 1 3 2 3 6 5 2 7 1 4 -1 2 1 7 3 5 6 1 2 4 -1 3 1 2 -1 5 2 4 3 1 6 -1 2 3 1 -1 -1 4 1 2 3 -1 -1 2 1 3 -1 -1 -1 -1 -1 1 2 -1 -1 -1 2 5 3 4 1 1 2 3 6 5 4 1 3 2 -1 5 7 4 3 1 2 6 2 4 1 5 3 -1 -1 2 4 3 6 1 5 -1 2 4 6 1 3 5 1 5 4 2 3 -1 -1 2 4 1 3 -1 ...
result:
ok 100 lines
Test #4:
score: 0
Accepted
time: 8ms
memory: 165520kb
input:
100 8 2 8 6 4 1 7 5 3 2 3 1 2 1 3 4 408738161 1 3 4 2 9 392326366 4 3 2 1 8 7 6 5 9 7 6 2 5 1 3 7 4 6 3 662976110 1 2 3 4 584704458 3 1 2 4 2 170402059 2 1 8 195525462 8 4 2 1 7 6 5 3 5 241372504 4 5 2 3 1 2 1 1 2 7 2 6 3 7 4 1 2 5 6 1 6 3 5 1 2 4 7 5 3 2 7 4 1 6 5 8 2 5 3 4 6 1 2 7 8 4 1 2 4 3 1 2 ...
output:
-1 1 3 2 -1 -1 3 4 2 1 6 5 7 -1 -1 -1 -1 -1 2 1 7 1 6 5 2 3 4 5 4 6 2 1 3 4 1 6 5 2 7 3 -1 1 3 4 2 -1 -1 2 1 3 -1 1 3 6 5 7 4 2 -1 -1 5 3 1 4 2 -1 -1 -1 -1 -1 3 5 2 4 6 1 3 1 2 -1 5 4 9 3 7 1 2 8 6 -1 -1 -1 -1 -1 -1 -1 2 1 3 2 1 -1 -1 1 6 5 2 4 3 7 8 -1 8 2 3 5 6 9 4 7 1 2 3 1 -1 -1 -1 -1 -1 3 6 4 5...
result:
ok 100 lines
Test #5:
score: 0
Accepted
time: 16ms
memory: 165656kb
input:
1000 4 2 2 1 4 3 3 1 3 2 1 7 110856137 6 5 1 7 4 2 3 7 253418683 2 6 7 4 3 1 5 2 2 1 2 7 763879058 7 5 3 1 6 4 2 8 518300421 1 8 4 2 3 5 7 6 3 241647870 2 1 3 4 400296427 2 1 4 3 3 477979797 1 3 2 6 2 4 1 3 6 5 2 8 2 3 7 5 4 2 8 1 6 8 1 3 2 1 5 7 8 6 4 3 2 2 3 1 9 3 1 6 7 2 5 4 3 8 9 5 1 3 2 5 1 4 4...
output:
-1 1 3 2 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 4 1 2 6 8 7 5 3 3 1 2 2 5 9 1 6 3 4 7 8 1 3 4 2 5 -1 -1 4 1 2 5 3 -1 3 8 2 1 5 9 7 6 4 -1 -1 4 3 2 7 1 5 6 -1 -1 -1 -1 -1 2 1 3 4 6 5 2 1 -1 -1 -1 2 1 3 -1 2 1 1 5 4 6 8 7 3 2 -1 -1 3 2 4 5 1 3 2 4 1 -1 3 1 2 3 2 1 4 -1 8 1 3 2 9 7 5 4 6 7 4 6 2 5 3 1 -1 -1 6 7...
result:
ok 1000 lines
Test #6:
score: 0
Accepted
time: 15ms
memory: 165844kb
input:
1000 6 2 6 4 2 3 1 5 9 7 6 5 3 9 1 7 2 8 4 8 290062773 5 2 6 7 8 3 4 1 6 764373478 6 2 1 5 4 3 2 2 2 1 4 280972480 1 4 2 3 3 931925743 2 3 1 5 698025972 2 5 3 1 4 3 260868128 3 2 1 4 15623583 3 4 2 1 5 2 2 5 1 4 3 7 5 3 1 5 4 2 6 7 10 2 1 5 4 3 8 2 9 7 10 6 7 3 5 2 4 6 7 1 3 10 1 5 9 2 8 7 1 4 6 10 ...
output:
-1 7 4 5 8 2 6 1 9 3 -1 -1 -1 -1 -1 -1 -1 -1 1 4 2 3 5 4 2 7 3 1 5 6 -1 4 1 5 7 6 3 2 6 10 1 7 8 2 3 5 9 4 4 5 1 2 3 -1 -1 4 2 6 1 9 7 3 5 8 -1 -1 -1 -1 -1 -1 -1 5 2 1 3 4 6 -1 -1 -1 9 5 2 4 7 3 1 6 8 -1 3 1 4 5 2 -1 5 7 1 6 2 4 8 9 3 -1 3 4 5 1 2 2 1 3 2 1 4 3 7 6 5 -1 -1 3 9 5 4 8 6 7 1 10 2 -1 8 ...
result:
ok 1000 lines
Test #7:
score: 0
Accepted
time: 875ms
memory: 168436kb
input:
100 3412 1 258 1465 305 1663 2883 340 3112 1078 1464 1315 1418 2018 141 2901 1121 1382 938 1208 3289 3016 2358 1270 1795 3335 1566 1284 2091 1582 3137 3276 2873 1838 2049 3274 438 266 2827 1337 440 1063 2895 2953 1433 84 253 1547 3360 3125 530 2708 2985 181 2559 3308 1660 1609 287 2737 1894 871 3048...
output:
257 1466 306 1664 2884 339 3111 1077 1463 1316 1417 2017 142 2902 1122 1381 937 1207 3290 3015 2357 1269 1796 3336 1565 1283 2092 1581 3138 3275 2874 1837 2050 3273 437 265 2828 1338 439 1064 2896 2954 1434 83 254 1548 3359 3126 529 2707 2986 182 2560 3307 1659 1610 288 2738 1893 872 3047 403 3361 8...
result:
ok 100 lines
Test #8:
score: 0
Accepted
time: 98ms
memory: 167308kb
input:
131 20 1 15 20 9 10 2 3 19 5 12 11 18 17 16 4 1 14 6 13 7 8 5 2 5 3 4 2 1 6 1 3 5 4 1 6 2 41 19 6 5 1 38 41 20 10 4 21 30 22 29 24 36 16 2 8 12 27 23 3 39 33 26 25 32 18 19 37 40 15 31 11 34 14 9 28 35 7 17 13 9 6 5 8 4 7 6 1 9 3 2 4 1 1 2 4 3 41 5 33 4 8 13 7 9 23 11 36 26 25 5 39 41 2 15 31 28 30 ...
output:
16 19 10 9 1 4 20 6 11 12 17 18 15 3 2 13 5 14 8 7 4 1 5 3 2 4 6 3 2 5 1 5 6 2 39 40 19 9 3 22 31 21 30 23 37 15 1 7 11 28 24 4 38 32 25 26 33 17 20 36 41 16 29 12 35 13 10 27 34 8 18 14 6 9 3 5 7 2 8 4 1 2 1 3 4 32 3 7 12 8 11 22 10 37 27 24 6 38 40 1 14 30 29 31 41 5 2 23 18 20 33 26 4 16 13 25 19...
result:
ok 131 lines
Test #9:
score: 0
Accepted
time: 18ms
memory: 165732kb
input:
1000 33 13 2 18 17 8 25 30 1 29 19 6 11 13 9 14 10 22 4 26 23 31 27 3 28 15 7 24 20 21 33 32 16 5 12 40 43 24 27 31 4 26 8 33 3 25 34 28 30 7 22 38 17 14 39 11 23 20 13 10 37 15 40 5 21 32 1 29 36 2 9 35 18 19 6 16 12 41 81 2 14 3 11 1 27 33 16 40 32 31 18 39 38 26 29 20 34 30 25 12 6 8 19 17 21 4 2...
output:
1 17 18 7 26 31 2 30 20 5 12 14 10 13 9 21 3 25 24 29 28 4 27 16 8 23 19 22 32 33 15 6 11 -1 -1 -1 19 9 7 6 12 5 13 15 8 3 18 14 1 4 11 10 17 16 2 -1 39 19 40 13 12 49 10 43 42 22 32 14 3 5 26 28 9 23 2 7 11 16 46 24 18 1 27 30 25 29 6 41 48 20 47 37 8 44 35 31 45 17 33 15 34 21 38 4 36 -1 -1 -1 20 ...
result:
ok 1000 lines
Test #10:
score: 0
Accepted
time: 32ms
memory: 166024kb
input:
1000 47 88 38 47 17 13 27 3 1 25 11 23 9 5 41 40 31 20 16 46 6 2 30 19 28 32 10 26 43 36 15 45 29 33 21 24 39 34 7 44 22 42 8 14 18 12 35 37 4 30 33 5 29 3 21 2 27 25 4 19 23 17 6 7 8 14 18 20 1 26 24 28 12 13 22 16 15 9 11 30 10 62 85 17 50 62 16 15 28 20 27 57 31 11 53 58 61 14 39 24 3 33 34 38 49...
output:
-1 -1 -1 2 17 65 8 80 6 81 15 26 16 83 59 68 91 33 40 61 78 74 12 92 75 70 64 7 21 24 23 38 62 29 45 84 34 20 39 85 9 86 30 41 57 56 27 13 52 79 88 82 72 55 47 42 89 90 11 5 31 73 1 77 51 67 76 19 60 18 25 32 93 35 4 49 28 48 69 87 22 46 43 71 66 37 63 50 10 54 53 58 36 44 3 14 -1 2 4 3 1 -1 -1 -1 -...
result:
ok 1000 lines
Test #11:
score: 0
Accepted
time: 220ms
memory: 165320kb
input:
10000 15 15 14 2 5 7 9 15 4 12 10 6 1 3 13 11 8 84 4 56 16 12 74 14 71 40 21 13 52 78 2 4 46 29 3 36 70 32 22 75 58 63 27 45 6 26 47 64 33 44 31 15 28 24 1 67 30 83 68 76 73 82 39 54 38 35 41 42 61 53 11 66 34 51 37 81 25 62 17 18 5 57 60 10 84 8 48 9 19 69 80 79 7 23 59 49 43 20 55 72 77 65 50 9 17...
output:
-1 -1 -1 -1 52 55 34 79 54 22 91 82 94 16 86 41 9 38 31 78 75 72 15 46 6 45 17 35 56 70 58 73 3 40 62 57 39 84 26 65 59 53 13 87 80 92 69 88 76 19 21 90 89 4 11 42 95 44 93 51 30 48 32 36 37 5 7 63 33 50 1 49 2 28 8 24 74 77 27 47 83 43 12 14 29 20 68 85 67 25 81 10 61 60 18 71 64 66 23 -1 67 80 22 ...
result:
ok 10000 lines
Test #12:
score: 0
Accepted
time: 441ms
memory: 167752kb
input:
1000 999 1602 532 982 788 569 395 942 891 814 393 246 562 806 668 631 296 787 663 782 641 448 971 98 170 14 361 249 46 133 484 402 41 608 885 825 790 724 614 304 411 644 779 567 290 931 449 47 242 121 708 433 16 358 536 933 784 773 180 851 80 459 896 254 956 604 970 540 215 541 537 639 669 939 943 3...
output:
-1 338 79 456 38 709 479 273 451 252 617 233 464 503 511 64 342 42 541 627 679 241 275 299 25 160 75 494 182 67 172 18 316 231 680 558 578 690 715 112 107 449 741 434 188 610 422 448 559 81 223 203 676 63 333 163 705 637 232 144 698 518 26 362 738 493 153 589 548 122 602 80 263 381 329 83 565 177 58...
result:
ok 1000 lines
Test #13:
score: 0
Accepted
time: 574ms
memory: 168180kb
input:
100 186 134 128 34 170 56 136 10 62 50 48 144 1 66 91 99 153 149 77 87 156 8 29 36 57 183 69 90 28 51 115 76 21 101 49 65 71 173 73 25 154 70 116 89 24 103 22 167 138 68 88 119 31 46 166 125 126 181 78 178 104 9 130 60 11 177 127 44 47 4 30 45 171 185 3 38 92 162 17 63 114 118 23 106 81 184 37 27 14...
output:
-1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 1732 762 2848 1365 107 1567 1202 2362 970 573 1051 2142 1037 1479 1003 24 439 2026 2352 304 2689 2579 500 1658 1232 6 1402 2824 2841 967 1044 411 2343 1322 1254 3015 1135 780 3125 1937 2494 232 1175 1807 1454 2582 853 3104 1475 1843 2059 2005 383 2929 ...
result:
ok 100 lines
Test #14:
score: 0
Accepted
time: 1480ms
memory: 168820kb
input:
10 32077 42391 17986 10802 3107 8912 23279 16553 26516 8313 5924 9342 3829 29290 420 18508 29472 24529 26449 5893 28485 983 8073 2722 21478 23941 22613 19864 12364 25856 27509 7951 21218 17202 13121 17591 11609 13300 15719 31876 26033 24795 25899 6433 15759 2051 29655 12031 17813 16091 28725 13894 1...
output:
-1 -1 14839 5132 2966 10074 468 13948 15989 2478 9665 9212 14639 13705 2031 13708 11921 1614 3620 20187 5082 6026 15300 2595 9727 11867 4001 10527 1418 3619 5085 3980 19407 3520 18446 11589 15261 2454 10763 9889 18895 19896 11432 2793 5 3503 19524 17879 7552 12847 12146 15744 15301 16217 18281 20746...
result:
ok 10 lines
Test #15:
score: 0
Accepted
time: 2432ms
memory: 171148kb
input:
5 200000 357261 49805 123255 26648 123787 16881 172698 147556 44746 40569 173176 122155 103751 174194 42928 65635 130130 149126 189179 107060 107100 24399 154028 105771 158652 109927 78981 3086 159721 126652 130391 194285 50663 143730 191701 193671 180950 28088 11584 174201 191920 25968 31954 116771...
output:
-1 143838 18024 41263 111462 34584 179044 118745 153971 5814 99626 107956 133071 46127 136547 100260 54744 167298 121071 166176 199011 132209 109000 47621 171257 168076 199027 190697 127624 194291 169706 63927 104217 38796 198715 49650 136501 132599 122404 169308 8320 55450 132159 83408 184311 18244...
result:
ok 5 lines
Extra Test:
score: 0
Extra Test Passed