QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#821527#9905. 哈夫曼树cooluo100 ✓1159ms16268kbC++2318.4kb2024-12-19 16:26:392024-12-19 16:26:41

Judging History

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

  • [2024-12-19 16:26:41]
  • 评测
  • 测评结果:100
  • 用时:1159ms
  • 内存:16268kb
  • [2024-12-19 16:26:39]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;

#define ll long long
#define ul unsigned ll
#define LL __int128_t
#define db double
#define DB long db
#define pii pair<int, int>
#define fi first
#define se second
#define mkpr make_pair
#define vi vector<int>
#define vii vector<pii>
#define eb emplace_back
#define all(c) (c).begin(), (c).end()
#define bit(k) (1 << (k))
#define BIT(k) (1ll << (k))
#define lsh(s, k) ((s) << (k))
#define rsh(s, k) ((s) >> (k))
#define bin(s, k) ((s) >> (k) & 1)
#define lg2(x) (31 - __builtin_clz(x))
#define popcnt(x) __builtin_popcount(x)
#define mem(a, x) memset(a, x, sizeof(a))
#define req(i, l, r) for (int i(l), i##End(r); i < i##End; i = -~i)
#define rep(i, l, r) for (int i(l), i##End(r); i <= i##End; i = -~i)
#define per(i, r, l) for (int i(r), i##End(l); i >= i##End; i = ~-i)

#ifdef JYR
#define errs(x) fputs(x "\n", stderr)
#define errm(x, ...) fprintf(stderr, x, ##__VA_ARGS__)
#else
#define errs(x) 0
#define errm(x, ...) 0
#endif

template<typename T, typename U> void chkmx(T &_a, U _b) { if (_a < _b) _a = _b; }
template<typename T, typename U> void chkmn(T &_a, U _b) { if (_a > _b) _a = _b; }
template<typename T> T sq(T x) { return x * x; }

bool Mbe;

struct FastIO {
    char buf[1 << 20], *p1, *p2;
    char puf[1 << 20], *pf;

    FastIO() : p1(buf), p2(buf), pf(puf) {}
    ~FastIO() { fwrite(puf, 1, pf - puf, stdout); }

    char gc() {
        if (p1 == p2) p2 = (p1 = buf) + fread(buf, 1, 1 << 20, stdin);
        return p1 == p2 ? EOF : *p1++;
    }

    bool blank(char c) { return c == ' ' || c == '\r' || c == '\n' || c == '\t'; }

    char rd() {
        char c = gc(); while (blank(c)) c = gc();
        return c;
    }

    template<typename T> T rd() {
        T x = 0; int f = 0; char c = gc();
        while (!isdigit(c)) f = (c == '-'), c = gc();
        while (isdigit(c)) x = (x << 1) + (x << 3) + (c - '0'), c = gc();
        return f ? -x : x;
    }

    int rds(char *s) {
        char c = gc(), *S = s;
        while (blank(c)) c = gc();
        if (c == EOF) return *s = 0;
        while (!blank(c) && c != EOF) *s++ = c, c = gc();
        return *s = 0, abs(s - S);
    }

    int rdl(char *s) {
        char c = gc(), *S = s;
        while (c == '\r' || c == '\n') c = gc();
        if (c == EOF) return *s = 0;
        while (c != '\r' && c != '\n' && c != EOF) *s++ = c, c = gc();
        return *s = 0, abs(s - S);
    }

    void rd(char &c) { c = rd(); }

    template<typename T> void rd(T &x) {
        x = 0; int f = 0; char c = gc();
        while (!isdigit(c)) f = (c == '-'), c = gc();
        while (isdigit(c)) x = (x << 1) + (x << 3) + (c - '0'), c = gc();
        if (f) x = -x;
    }

    template<typename T, typename... Ts>
    void rd(T& x, Ts&... xs) { rd(x), rd(xs...); }

    void pc(const char &c) {
        if (pf - puf == 1 << 20) fwrite(pf = puf, 1, 1 << 20, stdout);
        *pf++ = c;
    }

    void prt(char c) { pc(c); }

    template<typename T> void prt(T x) {
        static int st[41], tp = 0;
        if (x == 0) { pc('0'); return; }
        if (x < 0) x = -x, pc('-');
        while (x) st[++tp] = x % 10, x /= 10;
        while (tp) pc(st[tp--] + '0');
    }

    template<typename T> void prt(T *x) { while (*x) pc(*x++); }

    template<typename T, typename... Ts>
    void prt(T x, Ts... xs) { prt(x), prt(xs...); }

    void prts(const char *s, char c = '\n') {
        while (*s) pc(*s++);
        if (c) pc(c);
    }
} IO;

#define rd IO.rd
#define ri rd<int>()
#define rl rd<ll>()
#define prt IO.prt

// #define MC

#define N 200005
#define mod 998244353
#define inf 0x3f3f3f3f
#define INF 0x3f3f3f3f3f3f3f3f

#define pll pair<ll, ll>

int n, m, q, cnt;
ll a[N];
int lc[N], rc[N], fa[N];
int de[N];
multiset<pll> S;

pll llp(ll x, ll y) { return x < y ? mkpr(x, y) : mkpr(y, x); }

void ins(pll x) {
    auto it = S.emplace(x), nt = next(it);
    if (it != S.begin()) {
        auto pr = prev(it);
        if (pr->se > it->fi) cnt++;
        if (nt != S.end() && pr->se > nt->fi) cnt--;
    }
    if (nt != S.end() && it->se > nt->fi) cnt++;
}

void del(pll x) {
    auto it = S.find(x), nt = next(it);
    if (it != S.begin()) {
        auto pr = prev(it);
        if (pr->se > it->fi) cnt--;
        if (nt != S.end() && pr->se > nt->fi) cnt++;
    }
    if (nt != S.end() && it->se > nt->fi) cnt--;
    S.erase(it);
}

void init() {
    rep(u, n + 1, m) ins(llp(a[lc[u]], a[rc[u]]));
    IO.prts(!cnt ? "YES" : "NO");
}

void slv() {
    int u, U; ll k; rd(u, k), U = u;
    for (u = fa[U]; u; u = fa[u]) del(llp(a[lc[u]], a[rc[u]]));
    a[U] = k;
    for (u = fa[U]; u; u = fa[u]) a[u] = a[lc[u]] + a[rc[u]];
    for (u = fa[U]; u; u = fa[u]) ins(llp(a[lc[u]], a[rc[u]]));
    IO.prts(!cnt ? "YES" : "NO");
    // errm("slv(): %d\n", cnt);
    // for (auto [x, y] : S) errm(" | %lld %lld", x, y);
    // errs(" |");
}

void mslv() {
    rd(n, q), m = lsh(n, 1) - 1;
    rep(i, 1, n) rd(a[i]), de[i] = 1;
    rep(i, n + 1, m) {
        rd(lc[i], rc[i]);
        de[i] = max(de[lc[i]], de[rc[i]]) + 1;
        fa[lc[i]] = fa[rc[i]] = i;
        a[i] = a[lc[i]] + a[rc[i]];
    }
    if (*max_element(de + 1, de + m) > 75) {
        while (q--) IO.prts("NO");
        return;
    }
    init();
    while (q-->1) slv();
}

void mprw() {}

bool Med;

int main() {
    #ifdef JYR
    freopen("Test.in", "r", stdin);
    freopen("Test.out", "w", stdout);
    #endif
    mprw();
    #ifdef MC
    int _; scanf("%d", &_);
    while (_--) mslv();
    #else
    mslv();
    #endif
    errm("%.3lfMB %.0lfms\n", abs(&Med - &Mbe) / 1048576., clock() * 1000. / CLOCKS_PER_SEC);
    return 0;
}

// #include <bits/stdc++.h>
// using namespace std;

// #define ll long long
// #define ul unsigned ll
// #define LL __int128_t
// #define db double
// #define DB long db
// #define pii pair<int, int>
// #define fi first
// #define se second
// #define mkpr make_pair
// #define vi vector<int>
// #define vii vector<pii>
// #define eb emplace_back
// #define all(c) (c).begin(), (c).end()
// #define bit(k) (1 << (k))
// #define BIT(k) (1ll << (k))
// #define lsh(s, k) ((s) << (k))
// #define rsh(s, k) ((s) >> (k))
// #define bin(s, k) ((s) >> (k) & 1)
// #define lg2(x) (31 - __builtin_clz(x))
// #define popcnt(x) __builtin_popcount(x)
// #define mem(a, x) memset(a, x, sizeof(a))
// #define req(i, l, r) for (int i(l), i##End(r); i < i##End; i = -~i)
// #define rep(i, l, r) for (int i(l), i##End(r); i <= i##End; i = -~i)
// #define per(i, r, l) for (int i(r), i##End(l); i >= i##End; i = ~-i)

// #ifdef JYR
// #define errs(x) fputs(x "\n", stderr)
// #define errm(x, ...) fprintf(stderr, x, ##__VA_ARGS__)
// #else
// #define errs(x) 0
// #define errm(x, ...) 0
// #endif

// template<typename T, typename U> void chkmx(T &_a, U _b) { if (_a < _b) _a = _b; }
// template<typename T, typename U> void chkmn(T &_a, U _b) { if (_a > _b) _a = _b; }
// template<typename T> T sq(T x) { return x * x; }

// bool Mbe;

// struct FastIO {
//     char buf[1 << 20], *p1, *p2;
//     char puf[1 << 20], *pf;

//     FastIO() : p1(buf), p2(buf), pf(puf) {}
//     ~FastIO() { fwrite(puf, 1, pf - puf, stdout); }

//     char gc() {
//         if (p1 == p2) p2 = (p1 = buf) + fread(buf, 1, 1 << 20, stdin);
//         return p1 == p2 ? EOF : *p1++;
//     }

//     bool blank(char c) { return c == ' ' || c == '\r' || c == '\n' || c == '\t'; }

//     char rd() {
//         char c = gc(); while (blank(c)) c = gc();
//         return c;
//     }

//     template<typename T> T rd() {
//         T x = 0; int f = 0; char c = gc();
//         while (!isdigit(c)) f = (c == '-'), c = gc();
//         while (isdigit(c)) x = (x << 1) + (x << 3) + (c - '0'), c = gc();
//         return f ? -x : x;
//     }

//     int rds(char *s) {
//         char c = gc(), *S = s;
//         while (blank(c)) c = gc();
//         if (c == EOF) return *s = 0;
//         while (!blank(c) && c != EOF) *s++ = c, c = gc();
//         return *s = 0, abs(s - S);
//     }

//     int rdl(char *s) {
//         char c = gc(), *S = s;
//         while (c == '\r' || c == '\n') c = gc();
//         if (c == EOF) return *s = 0;
//         while (c != '\r' && c != '\n' && c != EOF) *s++ = c, c = gc();
//         return *s = 0, abs(s - S);
//     }

//     void rd(char &c) { c = rd(); }

//     template<typename T> void rd(T &x) {
//         x = 0; int f = 0; char c = gc();
//         while (!isdigit(c)) f = (c == '-'), c = gc();
//         while (isdigit(c)) x = (x << 1) + (x << 3) + (c - '0'), c = gc();
//         if (f) x = -x;
//     }

//     template<typename T, typename... Ts>
//     void rd(T& x, Ts&... xs) { rd(x), rd(xs...); }

//     void pc(const char &c) {
//         if (pf - puf == 1 << 20) fwrite(pf = puf, 1, 1 << 20, stdout);
//         *pf++ = c;
//     }

//     void prt(char c) { pc(c); }

//     template<typename T> void prt(T x) {
//         static int st[41], tp = 0;
//         if (x == 0) { pc('0'); return; }
//         if (x < 0) x = -x, pc('-');
//         while (x) st[++tp] = x % 10, x /= 10;
//         while (tp) pc(st[tp--] + '0');
//     }

//     template<typename T> void prt(T *x) { while (*x) pc(*x++); }

//     template<typename T, typename... Ts>
//     void prt(T x, Ts... xs) { prt(x), prt(xs...); }

//     void prts(const char *s, char c = '\n') {
//         while (*s) pc(*s++);
//         if (c) pc(c);
//     }
// } IO;

// #define rd IO.rd
// #define ri rd<int>()
// #define rl rd<ll>()
// #define prt IO.prt

// // #define MC

// #define N 200005
// #define mod 998244353
// #define inf 0x3f3f3f3f
// #define INF 0x3f3f3f3f3f3f3f3f

// int n, m, q, cnt;
// ll a[N];
// int lc[N], rc[N], f[N];
// ll mn[N], mx[N];
// ll MN[N], MX[N];
// bool tg[N];
// // bool vs[N];
// // priority_queue<ll, vector<ll>, greater<ll>> pq;
// // set<int> S;
// // map<ll, int> mp;

// // void ins(int i) {
// //     if (i > n) {
// //         S.emplace(i);
// //         mp[a[lc[i]]]++, mp[a[rc[i]]]++;
// //     }
// // }

// // void dfs(int i) {
// //     if (i <= n) return;
// //     int lc = lc[i - n], rc = rc[i - n];
// //     dfs(lc), dfs(rc), a[i] = a[lc] + a[rc];
// // }

// /*

// 绷,输入 ll -> int 硬控我 1h

// 现在有了大约 30pts,想想正解

// 已知:每个节点的儿子编号都小于自己(这个也 TM 才看到),也就是说只有两个儿子都 <= n 才可以换顺序

// 于是又收获了一种写暴力的方法 /qd

// 设 > n 为 X 点,其余为 O 点

//    X
//   / \
//  O   X
//     / \
//    O   O

// 对于这种情况,我们要求上一层的 O 严格大于下一层的 O(在同一棵子树内)

// !! 重要结论:树高不超过 log V = 60 层

// 现在只要快速处理 1. X 和 2. 一条 X 链就好了
//                 / \
//                O   O

// 记录每个数的前驱后继,应该可以处理 1. 了

// 貌似不用那么麻烦,直接使用暴力中的方法好像就行了:

// - 若 x < X < y 则不行
// - 若 X < x < Y 则不行
// - 若 x = X:
//   - 若 x < y, X < Y 则不行
//   - 若 x > y, X > Y 则不行

// 现在是 O(qlogV) 维护树,想要快速判正确性

// 猜:对于 u 的情况,充要条件是 v >= max{sub(w) - w}
//       /  \
//      v    w

// 证:看着很对

// 对个鬼,1423 就挂了

// 猜:{min{sub(v)},max.v} {min.w,max.w} 交不超过 1

// 证:看着很对

// 然后给炸了的位置打 tag 记 cnt 就好了?

// 生石灰,签到题硬控我 2.5h

// 好像前面那个才是对的?

// 对个鬼

// 现在急需 O(nq) 做法,这样就能优化了

// 必要条件 1:a[u] >= max{sub(v) - v} 反例是 1 4 2 3
// 必要条件 2:对于 a b c d - u v - x ,要求 [a,b] [c,d] 满足交集不超过一个数
// 去试试吧,反正已经暴毙了

// */

// bool init() {
//     // rep(i, 1, n) MN[i] = MX[i] = a[i];
//     rep(i, 1, n) mn[i] = mx[i] = a[i];
//     rep(u, n + 1, m) {
//         a[u] = a[lc[u]] + a[rc[u]];
//         mn[u] = min(mn[lc[u]], mn[rc[u]]);
//         mx[u] = max(mx[lc[u]], mx[rc[u]]);
//         cnt -= tg[u];
//         if (lc[u] > n && rc[u] > n) {
//             ll x = a[lc[lc[u]]], y = a[rc[lc[u]]];
//             ll X = a[lc[rc[u]]], Y = a[rc[rc[u]]];
//             if (x > y) swap(x, y);
//             if (X > Y) swap(X, Y);
//             tg[u] = max(x, X) < min(y, Y);
//         }
//         if (lc[u] > n) tg[u] |= a[rc[u]] < max(mx[lc[lc[u]]], mx[rc[lc[u]]]);
//         if (rc[u] > n) tg[u] |= a[lc[u]] < max(mx[lc[rc[u]]], mx[rc[rc[u]]]);
//         // mn[u] = min(MN[lc[u]], MN[rc[u]]);
//         // mx[u] = max(MX[lc[u]], MX[rc[u]]);
//         // MN[u] = min(mn[u], a[u]);
//         // MX[u] = max(mx[u], a[u]);
//         // if (lc[u] <= n && rc[u] <= n) continue;
//         // if      (lc[u] <= n) tg[u] = a[lc[u]] < mx[rc[u]];
//         // else if (rc[u] <= n) tg[u] = a[rc[u]] < mx[lc[u]];
//         // else {
//         //     ll x = max(mn[lc[u]], mn[rc[u]]);
//         //     ll y = min(mx[lc[u]], mx[rc[u]]);
//         //     errm("%d: [%lld %lld]\n", u, x, y);
//         //     tg[u] = x < y;
//         // }
//         cnt += tg[u];
//     }
//     errm("init(): %d\n", cnt);
//     rep(i, 1, m) errm("%d: %c | %lld | %lld %lld | %lld %lld\n", i, tg[i] ? 'N' : 'Y', a[i], mn[i], mx[i], MN[i], MX[i]);
//     return !cnt;
// }

// bool slv() {
//     // mp.clear(), mp[a[lc[m]]]++, mp[a[rc[m]]]++;
//     // S.clear(), S.emplace(lsh(n, 1) - 1);
//     // while (!S.empty()) {
//     //     bool fg = 0;
//     //     for (auto I = S.begin(); I != S.end(); I++) {
//     //         errs("?");
//     //         int i = *I;
//     //         ll X = a[lc[i]], Y = a[rc[i]];
//     //         if (X < Y) swap(X, Y);
//     //         auto it = prev(mp.end());
//     //         if (X != it->fi) continue;
//     //         if (it->se > 1) {
//     //             if (Y == it->fi) {
//     //                 S.erase(I), ins(lc[i]), ins(rc[i]);
//     //                 if (it->se == 2) mp.erase(it);
//     //                 else mp[X] -= 2;
//     //                 fg = 1; break;
//     //             }
//     //         } else {
//     //             auto ti = prev(it);
//     //             if (Y == ti->fi) {
//     //                 S.erase(I), ins(lc[i]), ins(rc[i]);
//     //                 mp.erase(it);
//     //                 if (ti->se == 1) mp.erase(ti);
//     //                 else mp[Y]--;
//     //                 fg = 1; break;
//     //             }
//     //         }
//     //     }
//     //     if (!fg) return 0;
//     // }
//     // req(i, 1, n) a[i + n] = a[lc[i]] + a[rc[i]];
//     // dfs(rt);
//     // errs("slv():");
//     // rep(i, 1, m) errm(" | %lld\n", a[i]);
//     // errs(" |");
//     // while (!pq.empty()) pq.pop();
//     // mem(vs, 0);
//     // rep(i, 1, n) pq.emplace(a[i]), vs[i] = 1;
//     // while (pq.size() > 1) {
//     //     bool fg = 0;
//     //     req(i, 1, n) if (!vs[i + n] && vs[lc[i]] && vs[rc[i]]) {
//     //         ll x = pq.top(); pq.pop();
//     //         ll X = a[lc[i]], Y = a[rc[i]];
//     //         if (X > Y) swap(X, Y);
//     //         if (x == X && Y == pq.top()) {
//     //             fg = vs[i + n] = 1, pq.pop(), pq.emplace(X + Y);
//     //             break;
//     //         } else pq.emplace(x);
//     //     }
//     //     if (!fg) return 0;
//     // }
//     // req(i, 1, n) {
//     //     ll x = a[lc[i]], y = a[rc[i]];
//     //     if (x > y) swap(x, y);
//     //     // errm(" - %d: %lld %lld\n", i, x, y);
//     //     req(j, i + 1, n) {
//     //         ll X = a[lc[j]], Y = a[rc[j]];
//     //         if (X > Y) swap(X, Y);
//     //         // errm(" | %d: %lld %lld\n", j, X, Y);
//     //         if ((x < X && X < y) || (X < x && x < Y)
//     //          || (x == X && ((x < y && X < Y) || (x > y && X > Y)))) return 0;
//     //     }
//     // }
//     int u = ri;
//     a[u] = mn[u] = mx[u] = rl;
//     // a[u] = MN[u] = MX[u] = rl;
//     for (u = f[u]; u; u = f[u]) {
//         a[u] = a[lc[u]] + a[rc[u]];
//         mn[u] = min(mn[lc[u]], mn[rc[u]]);
//         mx[u] = max(mx[lc[u]], mx[rc[u]]);
//         cnt -= tg[u];
//         if (lc[u] > n && rc[u] > n) {
//             ll x = a[lc[lc[u]]], y = a[rc[lc[u]]];
//             ll X = a[lc[rc[u]]], Y = a[rc[rc[u]]];
//             if (x > y) swap(x, y);
//             if (X > Y) swap(X, Y);
//             tg[u] = max(x, X) < min(y, Y);
//         } else tg[u] = 0;
//         if (lc[u] > n) tg[u] |= a[rc[u]] < max(mx[lc[lc[u]]], mx[rc[lc[u]]]);
//         if (rc[u] > n) tg[u] |= a[lc[u]] < max(mx[lc[rc[u]]], mx[rc[rc[u]]]);
//         // mn[u] = min(MN[lc[u]], MN[rc[u]]);
//         // mx[u] = max(MX[lc[u]], MX[rc[u]]);
//         // MN[u] = min(mn[u], a[u]);
//         // MX[u] = max(mx[u], a[u]);
//         // if (lc[u] <= n && rc[u] <= n) continue;
//         // if      (lc[u] <= n) tg[u] = a[lc[u]] < mx[rc[u]];
//         // else if (rc[u] <= n) tg[u] = a[rc[u]] < mx[lc[u]];
//         // else {
//         //     ll x = max(mn[lc[u]], mn[rc[u]]);
//         //     ll y = min(mx[lc[u]], mx[rc[u]]);
//         //     errm("%d: [%lld %lld]\n", u, x, y);
//         //     tg[u] = x < y;
//         // }
//         cnt += tg[u];
//     }
//     errm("slv(): %d\n", cnt);
//     rep(i, 1, m) errm("%d: %c | %lld | %lld %lld | %lld %lld\n", i, tg[i] ? 'N' : 'Y', a[i], mn[i], mx[i], MN[i], MX[i]);
//     return !cnt;
// }

// void mslv() {
//     rd(n, q), m = lsh(n, 1) - 1;
//     rep(i, 1, n) rd(a[i]);
//     rep(i, n + 1, m) rd(lc[i], rc[i]), f[lc[i]] = f[rc[i]] = i;
//     // req(i, 1, n) rd(lc[i + n], rc[i + n]);
//     // req(i, 1, n) rd(lc[i], rc[i]);//, vs[lc[i]] = vs[rc[i]] = 1;
//     // req(i, 1, n) if (!vs[i + n]) { rt = i + n; break; }
//     IO.prts(init() ? "YES" : "NO");
//     while (q-->1) IO.prts(slv() ? "YES" : "NO");
// }

// void mprw() {}

// bool Med;

// int main() {
//     #ifdef JYR
//     // freopen("Test.err", "w", stderr);
//     freopen("Test.in", "r", stdin);
//     freopen("Test.out", "w", stdout);
//     #endif
//     mprw();
//     #ifdef MC
//     int _; scanf("%d", &_);
//     while (_--) mslv();
//     #else
//     mslv();
//     #endif
//     errm("%.3lfMB %.0lfms\n", abs(&Med - &Mbe) / 1048576., clock() * 1000. / CLOCKS_PER_SEC);
//     return 0;
// }

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

详细

Subtask #1:

score: 30
Accepted

Test #1:

score: 30
Accepted
time: 0ms
memory: 9736kb

input:

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

output:

YES
NO
YES
NO

result:

ok 4 token(s): yes count is 2, no count is 2

Test #2:

score: 30
Accepted
time: 0ms
memory: 9724kb

input:

8 5
5 3 4 2 2 6 5 5
1 8
4 5
10 3
11 9
7 2
6 13
14 12
7 3
6 8
4 2
2 5

output:

NO
YES
YES
YES
NO

result:

ok 5 token(s): yes count is 3, no count is 2

Test #3:

score: 30
Accepted
time: 1ms
memory: 7700kb

input:

5 1000
193989534544158 57483670601746 183281373434588 92196008024549 197513473286508
1 5
4 2
7 3
8 6
2 65545142774024
4 67957472319495
5 131478473459166
2 102185858570152
3 191441353035940
5 186000528093501
2 63201184033501
2 77481806092413
3 159789430863849
4 92773786021894
1 194598667478593
3 1458...

output:

YES
YES
YES
NO
NO
NO
NO
NO
NO
YES
YES
YES
YES
YES
YES
YES
YES
NO
NO
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
YES
NO
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
YES
YES
YES
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
YES
...

result:

ok 1000 token(s): yes count is 375, no count is 625

Test #4:

score: 30
Accepted
time: 1ms
memory: 7692kb

input:

7 1000
88159166205053 95998544558881 48231159865354 231786835189365 84291070100955 225941839972605 33315221625793
2 5
6 4
7 3
1 10
8 11
9 12
6 150843468162951
2 75759088055460
1 86133344610051
4 140694127444493
1 63070113756930
1 90150689680608
6 147790469610032
7 46561924657801
2 103953340734616
6 ...

output:

NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
N...

result:

ok 1000 token(s): yes count is 86, no count is 914

Test #5:

score: 30
Accepted
time: 0ms
memory: 7676kb

input:

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

output:

NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
YES
YES
YES
YES
NO
YES
NO
YES
YES
YES
YES
YES
YES
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
NO
YES
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO...

result:

ok 1000 token(s): yes count is 199, no count is 801

Test #6:

score: 30
Accepted
time: 1ms
memory: 7688kb

input:

8 1000
172480280419267 212072146993988 23147786306112 161006134777989 37963466387491 50018942108886 18649770050090 50499101532214
7 3
2 1
5 8
9 6
12 11
4 13
10 14
5 57899673021751
7 22087918088240
1 236990257757485
3 21994370580136
7 26427284121647
8 54391900162086
7 27709763713585
6 59631479929866
...

output:

NO
NO
NO
YES
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
YES
NO
NO
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES...

result:

ok 1000 token(s): yes count is 119, no count is 881

Test #7:

score: 30
Accepted
time: 1ms
memory: 7764kb

input:

6 1000
20326746134626 98517002313418 165556087937310 116347939244398 130872245741329 136674587230071
2 3
6 7
8 1
9 5
10 4
4 31902652070998
2 20697837065544
3 14389422108471
5 45879772826060
2 23505088168423
6 7588643182717
2 13873224035289
4 3462171437780
6 12963735380517
6 3348685354818
3 141429739...

output:

NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO...

result:

ok 1000 token(s): yes count is 12, no count is 988

Test #8:

score: 30
Accepted
time: 5ms
memory: 9688kb

input:

72 1000
2 10946 610 987 139583862445 20365011074 5 1597 196418 377 267914296 44945570212853 956722026041 5702887 39088169 75025 27777890035288 12586269025 4181 1 53316291173 144 1548008755920 63245986 1 225851433717 6557470319842 832040 2504730781961 102334155 55 3 46368 7778742049 6765 165580141 72...

output:

YES
NO
YES
NO
YES
NO
YES
NO
YES
YES
YES
NO
YES
NO
YES
NO
YES
YES
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
YES
YES
NO
YES
NO
YES
NO
YES
YES
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
YES
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
NO
YES
YES
YES
NO
YES
NO
YES
YES
YES
YES
YES
N...

result:

ok 1000 token(s): yes count is 598, no count is 402

Test #9:

score: 30
Accepted
time: 4ms
memory: 7608kb

input:

70 1000
31322671994689 1078810887856 579849 254672704401 136883 4713 4569916255830 11964196083506 19970 22963823428 157396387326 488813369 12341 1 61 1799 162 82003819900560 221480 5421023350 44076273 37 261 347373755513422 6430641 938216 71316908 687 7394279827673 302103276 2456284 32311 1745552683...

output:

YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
...

result:

ok 1000 token(s): yes count is 986, no count is 14

Test #10:

score: 30
Accepted
time: 4ms
memory: 9852kb

input:

1000 1000
696394773309 108383178182 819893348793 723784375461 931503257800 952660789032 100236017416 539829053718 209653090976 981815062655 964960614840 961643834067 369486282052 800646303984 387416608811 261777906950 172691588923 485971148690 453102872226 770561490733 375803723200 861225005889 1185...

output:

YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
NO
NO
NO
NO
YES
NO
NO
YES
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
YES
YES
YES
YES
NO
NO
YES
YES
NO
YES
YES
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
NO
NO
NO
NO
...

result:

ok 1000 token(s): yes count is 290, no count is 710

Test #11:

score: 30
Accepted
time: 4ms
memory: 7828kb

input:

1000 1000
328753409716 63174357177 116706499724 751756098545 913879475315 309225707947 610363994448 928602608183 298378305770 255654307269 444288397875 332511908079 297834684008 532592347055 268793918986 782156365515 316531786356 584037378094 809660826672 456709928147 277332 603219716866 60062165567...

output:

YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
...

result:

ok 1000 token(s): yes count is 124, no count is 876

Test #12:

score: 30
Accepted
time: 0ms
memory: 7832kb

input:

1000 1000
596779917266 859728384612 790999537569 946122172426 539615683280 616114813176 675147442971 523252967306 989540738771 880850130723 850501333358 858531013132 700803829612 642617589194 814265292894 799430766156 589454900606 735369030885 797404510621 602718454036 883696282103 974675349909 7793...

output:

YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
...

result:

ok 1000 token(s): yes count is 3, no count is 997

Test #13:

score: 30
Accepted
time: 5ms
memory: 9776kb

input:

1000 1000
12340874 29443 42 12492 139286 153819 53474891 4999 5513602 15 15542744701 367380 19381 1390668 27542397298 328751473 10398280 3528202605 126026926 21552 4031001 14293341319 140519268911 360904 1422 28 13089 32427234919 457240409937 17711545787 39539446 51 355784231 810175146335 916553144 ...

output:

YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
YES
YES
YES
NO
NO
YES
NO
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
NO
NO
YES
YES
YES
YES
YES
YES
YES
Y...

result:

ok 1000 token(s): yes count is 749, no count is 251

Test #14:

score: 30
Accepted
time: 3ms
memory: 9860kb

input:

1000 1000
19 27 18 26 41 49 29 27 46 24 43 25 50 4 17 25 15 15 4 33 24 35 10 7 27 3 39 43 36 28 29 5 20 5 42 43 33 17 11 26 43 21 38 31 12 33 48 33 14 29 48 49 15 37 16 4 16 44 25 45 41 17 37 49 32 40 9 12 8 22 2 24 9 21 14 16 34 45 47 25 28 16 26 7 11 42 26 29 35 32 34 44 11 30 20 47 13 6 41 19 37 ...

output:

YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
N...

result:

ok 1000 token(s): yes count is 468, no count is 532

Test #15:

score: 30
Accepted
time: 1ms
memory: 7668kb

input:

1000 1000
996069901379 940888328260 925342655682 923520191546 877076702411 855421610507 842224729549 837033687452 810175146335 792646717951 752993949814 717579080665 711089804069 708221643771 699280599587 697696794210 670880120082 641841749136 631447339331 619769332589 617930141820 586690159836 5636...

output:

NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
...

result:

ok 1000 token(s): yes count is 0, no count is 1000

Subtask #2:

score: 20
Accepted

Test #16:

score: 20
Accepted
time: 33ms
memory: 8504kb

input:

10000 10000
85117964119 41472951000 61693640396 66409648221 91978532661 62922448518 92497200794 43837348258 45577855926 38256001396 79446271832 95289903258 62510175551 97599809584 56162244722 87617641117 64010325734 56604859803 58544571483 40687963085 38627694508 64665875035 62273927372 73014847094 ...

output:

YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
N...

result:

ok 10000 token(s): yes count is 1207, no count is 8793

Test #17:

score: 20
Accepted
time: 23ms
memory: 10496kb

input:

10000 10000
84900060848 62644704574 98718077349 98821154996 62378873948 84056095227 88175599645 82631986335 89400902292 62154382134 88902573868 60394670260 90463768093 55792148201 54981081426 88759069805 61152773490 92471234756 97882399939 60966664424 77983213922 86899012963 99014573954 61451810141 ...

output:

YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO...

result:

ok 10000 token(s): yes count is 1, no count is 9999

Test #18:

score: 20
Accepted
time: 56ms
memory: 10444kb

input:

10000 10000
93919 1531126631 30535211 270124792 175 384 79432924528 57926141453 28 5497 3726 1802376440 193463181 493828 69230 574 52891249 4467144512 249874064 679 384407292 1656687680 6538 1702 531231 20166752330 15505 82 3284 4814 162 15208812 17569 809 5204 703838 3627957764 44761779 7256061080 ...

output:

YES
YES
NO
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
N...

result:

ok 10000 token(s): yes count is 463, no count is 9537

Test #19:

score: 20
Accepted
time: 2ms
memory: 9816kb

input:

10000 10000
99806537703 99766194869 99292379197 99207104032 99114739849 98889965040 98714163547 98624741525 98537071301 98408984814 97981236991 97867856128 97728640101 97720014922 97379361440 97285651187 97111208501 97096802253 96643517597 96360376855 95783851225 95377161230 95072710034 94889685140 ...

output:

NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
...

result:

ok 10000 token(s): yes count is 0, no count is 10000

Subtask #3:

score: 30
Accepted

Test #20:

score: 30
Accepted
time: 224ms
memory: 12008kb

input:

50000 50000
16394396247 17456058492 11358090355 13208121167 8612535629 2853817504 18100755237 18603321637 1618810635 7615832530 13631222424 7817630977 10963098997 19654927084 645638016 9352759139 17939720223 15106346489 14475376391 2122412099 15482023637 11224675857 15931143509 4240408932 1270948838...

output:

YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO...

result:

ok 50000 token(s): yes count is 6146, no count is 43854

Test #21:

score: 30
Accepted
time: 214ms
memory: 12240kb

input:

50000 50000
16115874901 16018205653 14928961193 15204162048 13699373395 16820637318 16493035276 12317462119 12335280079 14846384661 17397129601 13936553564 14115670390 10273255127 15120549487 18610914980 11122287472 11331160875 18972429908 12783865866 14407025341 18691310891 11400735942 15689404271 ...

output:

YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO...

result:

ok 50000 token(s): yes count is 97, no count is 49903

Test #22:

score: 30
Accepted
time: 455ms
memory: 11848kb

input:

50000 50000
3993 223081374 1585900689 19301459402 43 928559 17 9528421232 1595336240 17039424626 8356250 531391708 1218 551210298 37104 110710 81842739 119946920 37855516 10200 438 2736 201 23 1438 378221115 23 81 8281519 4554 205450323 52777 10352 45646 15 116342579 4459504 31 19342289293 483194 76...

output:

YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
...

result:

ok 50000 token(s): yes count is 448, no count is 49552

Test #23:

score: 30
Accepted
time: 0ms
memory: 10020kb

input:

50000 50000
19988593123 19987997685 19985224140 19980200906 19974260733 19973543573 19966775533 19962491364 19957673556 19951057741 19934887728 19924084943 19912519998 19910951955 19909656706 19908299113 19905363420 19903730114 19900763202 19883792717 19866579628 19863208341 19860493642 19841577977 ...

output:

NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
...

result:

ok 50000 token(s): yes count is 0, no count is 50000

Subtask #4:

score: 20
Accepted

Test #24:

score: 20
Accepted
time: 292ms
memory: 8876kb

input:

70 100000
66748 126 1 91045172 3605661959574 274077743637349 147314183 8209537 740253 6920630855 25494 1377240316614 15756 6 108000 18118446805 169389361127761 29316262755 48 2643445763 5834083602536 3 9439745562111 29 3719 10 47434709561 11197815949 6018 325122336074 851181326345 1633739329 1527382...

output:

YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
...

result:

ok 100000 token(s): yes count is 98093, no count is 1907

Test #25:

score: 20
Accepted
time: 471ms
memory: 16076kb

input:

100000 100000
7549638646 8066727970 9672316362 9615802181 6376690689 416134043 5288164622 2316444041 8423663950 1806779510 3010692396 7782858557 4229348735 1361364214 9005774175 6382408188 8174082766 8406340542 8599848784 3178078732 1395839441 5310497981 6807939596 2743315129 3143071583 3636776799 5...

output:

YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
...

result:

ok 100000 token(s): yes count is 14280, no count is 85720

Test #26:

score: 20
Accepted
time: 440ms
memory: 15804kb

input:

100000 100000
872896800 2642237960 7854830770 2526006918 2460372877 6275745887 9542824270 2259554484 7939727171 5684426763 3142930947 4722146974 4449153152 6010317250 9601373467 1320115120 1554509921 9484729979 4623237659 8207960981 9918495458 5636697884 8103563399 2247522457 3949979832 5293808722 8...

output:

YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
...

result:

ok 100000 token(s): yes count is 13620, no count is 86380

Test #27:

score: 20
Accepted
time: 397ms
memory: 15772kb

input:

100000 100000
7198797097 5435854448 9924139315 6509926805 6680038286 7582083493 8295697626 7987541001 6072017580 7487771114 7193879849 5761987728 8304525744 9604078001 6299845419 6733294485 9820196538 9587148702 5909774105 8852968034 9179846573 6366260329 7688429446 6297118602 7348639021 6888450227 ...

output:

YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO...

result:

ok 100000 token(s): yes count is 33, no count is 99967

Test #28:

score: 20
Accepted
time: 1159ms
memory: 16268kb

input:

100000 100000
4056837102 824104887 186 1311392 9313623872 8480 77121209 51422880 21389 15291 576956653 836 3456 7213630426 8779959870 273146 246 2205733 2579200972 36389 90998675 61 303221391 699293 10264244 6947232 2591 387 5853095 85 89 241 1603 704 2070710485 1762025505 8455788725 2962231 1657062...

output:

YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
NO
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
NO
YES
YES
YES
YES
YES
YES
YES
YES
YES
YES
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO...

result:

ok 100000 token(s): yes count is 350, no count is 99650

Test #29:

score: 20
Accepted
time: 3ms
memory: 10084kb

input:

100000 100000
9999834711 9998930249 9995255552 9993501823 9990418195 9989945168 9988551585 9988190213 9985354954 9985308095 9984359451 9982945279 9982266980 9981553307 9981304989 9979767996 9979737063 9978618141 9971036317 9967584170 9965984612 9962485753 9958389098 9952132366 9951200056 9948789025 ...

output:

NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
NO
...

result:

ok 100000 token(s): yes count is 0, no count is 100000

Extra Test:

score: 0
Extra Test Passed