UOJ Logo

NOI.AC

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#213589#2770. 子序列ThySecret05829ms92808kbC++112.6kb2024-11-12 21:22:072024-11-12 23:51:50

answer

#include <bits/stdc++.h>

using namespace std;

#define int long long
// #define x first
// #define y second
#define File(a) freopen(a".in", "r", stdin), freopen(a".out", "w", stdout)

inline void debug() { cerr << '\n'; }
template<typename Type, typename... Other>
inline void debug(const Type& x, const Other&... y) { cerr << x << ' '; debug(y...); }
#define DEBUG(a...) cerr << "[" << #a << "] = ", debug(a);

typedef long long LL;
typedef pair<int, int> PII;

const int N = 200010;
const int INF = 0x3f3f3f3f;
const int mod = 998244353;

template<typename Type>
inline void read(Type &res)
{
    res = 0;
    int ch = getchar(), flag = 0;
    while (!isdigit(ch)) flag |= ch == '-', ch = getchar();
    while (isdigit(ch)) res = (res << 3) + (res << 1) + (ch ^ 48), ch = getchar();
    res = flag ? -res : res;
}
template<typename Type, typename... Other>
inline void read(Type &res, Other&... y) { read(res), read(y...); }

int n, m, q;
int a[N];

struct SegsTree
{
    #define lc u << 1
    #define rc u << 1 | 1
    struct Node { int l, r, cnt[20]; } tr[N << 2];

    friend Node operator + (const Node &a, const Node &b) 
    {
        Node res = {a.l, b.r, {0}};
        for (int i = 0; i < m; i ++) res.cnt[i] = a.cnt[i];
        for (int i = 0; i < m; i ++) res.cnt[i] = (res.cnt[i] + b.cnt[i]) % mod;
        
        for (int i = 0; i < m; i ++)
            for (int j = 0; j < m; j ++)
                res.cnt[(i + j) % m] = (res.cnt[(i + j) % m] + a.cnt[i] * b.cnt[j] % mod) % mod;
        return res;
    }

    inline void pushup(int u) { tr[u] = tr[lc] + tr[rc]; }

    void build(int u, int l, int r)
    {
        tr[u].l = l, tr[u].r = r;
        if (l == r) return tr[u].cnt[a[l] % m] = 1, void();
        int mid = l + r >> 1;
        build(lc, l, mid), build(rc, mid + 1, r);
        pushup(u);
    }

    Node query(int u, int l, int r)
    {
        if (l <= tr[u].l && tr[u].r <= r)
            return tr[u];
        int mid = tr[u].l + tr[u].r >> 1;
        if (l > mid) return query(rc, l, r);
        else if (r <= mid) return query(lc, l, r);
        else return query(lc, l, r) + query(rc, l, r);
    }
} SGT;

signed main()
{
    read(n, m);
    for (int i = 1; i <= n; i ++) read(a[i]);
    SGT.build(1, 1, n);

    // DEBUG(SGT.tr[1].cnt[0]);

    // read(q);
    // while (q --)
    // {
    //     int l, r; read(l, r);
    //     // cout << SGT.query(1, l, r) << '\n';
    //     SegsTree::Node res = SGT.query(1, l, r);
    //     cout << res.cnt[0] + 1 << '\n';
    // }

    return 0;
}

详细

小提示:点击横条可展开更详细的信息

Test #1:

score: 0
Wrong Answer
time: 0ms
memory: 1136kb

input:

10 20
7 5 5 1 7 13 19 10 2 7
10
10 10
6 7
6 8
4 10
8 9
5 8
6 10
5 5
2 6
6 8

output:


result:

wrong answer 1st lines differ - expected: '1', found: ''

Test #2:

score: 0
Wrong Answer
time: 0ms
memory: 1136kb

input:

10 20
15 0 15 10 6 18 1 13 3 1
10
1 2
4 9
3 7
4 8
6 10
2 3
1 4
2 5
2 9
5 9

output:


result:

wrong answer 1st lines differ - expected: '2', found: ''

Test #3:

score: 0
Wrong Answer
time: 0ms
memory: 1132kb

input:

10 20
8 9 17 13 10 13 16 11 19 3
10
6 9
3 9
2 6
1 10
5 10
6 10
4 5
2 4
10 10
3 5

output:


result:

wrong answer 1st lines differ - expected: '2', found: ''

Test #4:

score: 0
Wrong Answer
time: 0ms
memory: 1136kb

input:

10 20
12 8 11 1 0 3 2 3 19 17
10
5 7
1 3
1 10
2 6
4 10
5 9
5 9
3 10
4 8
4 8

output:


result:

wrong answer 1st lines differ - expected: '2', found: ''

Test #5:

score: 0
Wrong Answer
time: 0ms
memory: 1132kb

input:

10 20
7 0 2 2 8 12 10 7 1 2
10
9 9
6 9
3 7
3 8
1 6
2 4
6 8
4 5
1 6
8 9

output:


result:

wrong answer 1st lines differ - expected: '1', found: ''

Test #6:

score: 0
Wrong Answer
time: 0ms
memory: 1168kb

input:

100 20
3 15 11 17 7 9 16 11 6 0 1 1 19 15 18 0 14 12 17 9 19 12 18 9 4 14 11 5 18 10 4 18 14 8 14 8 ...

output:


result:

wrong answer 1st lines differ - expected: '2', found: ''

Test #7:

score: 0
Wrong Answer
time: 0ms
memory: 1172kb

input:

100 20
3 7 17 4 9 6 6 15 18 1 3 5 19 13 2 7 9 10 4 5 0 10 18 18 6 0 1 15 16 12 2 7 6 0 17 2 14 18 4 ...

output:


result:

wrong answer 1st lines differ - expected: '3355488', found: ''

Test #8:

score: 0
Wrong Answer
time: 0ms
memory: 1176kb

input:

100 20
1 11 5 10 8 2 11 14 2 11 7 4 13 4 2 1 13 4 0 13 4 8 3 12 12 17 12 13 16 2 5 12 13 0 5 11 0 7 ...

output:


result:

wrong answer 1st lines differ - expected: '26391984', found: ''

Test #9:

score: 0
Wrong Answer
time: 0ms
memory: 1172kb

input:

100 20
8 18 4 8 11 9 1 19 7 14 7 13 4 3 14 0 10 3 13 16 2 5 17 18 7 10 7 3 19 1 16 18 7 13 19 13 2 1...

output:


result:

wrong answer 1st lines differ - expected: '804', found: ''

Test #10:

score: 0
Wrong Answer
time: 0ms
memory: 1172kb

input:

100 20
17 1 13 11 0 8 12 2 4 15 14 18 6 6 5 16 18 4 6 19 4 0 4 6 10 19 5 4 18 17 14 16 3 0 1 6 2 4 0...

output:


result:

wrong answer 1st lines differ - expected: '107223667', found: ''

Test #11:

score: 0
Wrong Answer
time: 6ms
memory: 1492kb

input:

1000 20
7 14 19 15 16 8 19 15 5 5 6 3 4 16 0 1 7 6 14 3 12 2 4 5 16 12 12 8 1 9 6 13 4 10 12 16 11 7...

output:


result:

wrong answer 1st lines differ - expected: '339309012', found: ''

Test #12:

score: 0
Wrong Answer
time: 6ms
memory: 1492kb

input:

1000 20
16 7 12 15 13 10 8 1 14 16 13 6 16 7 4 11 0 17 6 3 4 8 17 10 3 11 18 13 17 19 15 4 7 17 12 4...

output:


result:

wrong answer 1st lines differ - expected: '12', found: ''

Test #13:

score: 0
Wrong Answer
time: 6ms
memory: 1488kb

input:

1000 20
7 7 16 0 12 6 11 3 7 16 12 11 1 7 17 0 11 8 14 17 8 17 7 18 1 11 14 0 6 5 10 0 12 15 1 4 5 1...

output:


result:

wrong answer 1st lines differ - expected: '425631668', found: ''

Test #14:

score: 0
Wrong Answer
time: 3ms
memory: 1492kb

input:

1000 20
19 3 14 11 9 17 18 4 11 5 0 18 2 11 13 12 8 10 15 19 12 9 2 15 5 19 14 17 17 7 18 5 2 8 5 0 ...

output:


result:

wrong answer 1st lines differ - expected: '778881096', found: ''

Test #15:

score: 0
Wrong Answer
time: 3ms
memory: 1484kb

input:

1000 20
16 19 4 2 2 19 19 5 11 4 16 7 17 6 11 11 7 10 6 3 15 1 11 12 5 11 12 13 3 10 12 2 19 9 4 8 6...

output:


result:

wrong answer 1st lines differ - expected: '137484337', found: ''

Test #16:

score: 0
Wrong Answer
time: 55ms
memory: 6840kb

input:

10000 20
12 8 12 19 9 19 1 10 19 11 12 10 19 5 0 16 17 1 9 18 18 13 6 0 14 16 6 6 3 6 17 2 13 19 13 ...

output:


result:

wrong answer 1st lines differ - expected: '874193350', found: ''

Test #17:

score: 0
Wrong Answer
time: 55ms
memory: 6844kb

input:

10000 20
8 15 6 17 5 13 11 1 7 9 16 16 15 12 4 19 18 2 3 10 13 15 12 5 3 6 15 2 0 11 8 19 13 18 12 1...

output:


result:

wrong answer 1st lines differ - expected: '11498054', found: ''

Test #18:

score: 0
Wrong Answer
time: 53ms
memory: 6840kb

input:

10000 20
0 9 6 6 17 19 11 13 18 14 0 10 3 0 0 11 12 11 2 19 18 12 13 16 8 7 14 12 10 2 7 3 4 18 10 1...

output:


result:

wrong answer 1st lines differ - expected: '963045808', found: ''

Test #19:

score: 0
Wrong Answer
time: 47ms
memory: 6840kb

input:

10000 20
5 13 8 2 2 13 16 17 9 8 15 10 1 12 2 18 19 1 0 17 9 7 16 14 0 9 19 14 13 3 19 17 5 3 19 17 ...

output:


result:

wrong answer 1st lines differ - expected: '875247851', found: ''

Test #20:

score: 0
Wrong Answer
time: 55ms
memory: 6840kb

input:

10000 20
5 8 19 15 4 8 12 14 4 5 16 13 17 9 3 3 15 4 15 19 17 8 14 16 16 13 19 18 19 7 13 5 11 11 12...

output:


result:

wrong answer 1st lines differ - expected: '48', found: ''

Test #21:

score: 0
Wrong Answer
time: 1059ms
memory: 92804kb

input:

200000 20
11 5 3 3 2 9 10 10 15 4 19 1 3 0 19 19 15 0 0 12 14 16 1 8 3 18 10 6 14 11 2 7 17 2 0 1 12...

output:


result:

wrong answer 1st lines differ - expected: '57545307', found: ''

Test #22:

score: 0
Wrong Answer
time: 1297ms
memory: 92804kb

input:

200000 20
13 15 5 3 2 0 3 4 6 16 14 0 4 11 8 10 18 5 3 12 1 7 2 16 13 19 16 16 3 16 6 8 2 6 10 0 13 ...

output:


result:

wrong answer 1st lines differ - expected: '110393808', found: ''

Test #23:

score: 0
Wrong Answer
time: 1069ms
memory: 92808kb

input:

200000 20
15 8 8 12 19 10 4 14 16 6 3 17 13 4 14 17 5 15 19 4 0 3 17 5 4 9 14 19 10 11 9 13 0 3 18 0...

output:


result:

wrong answer 1st lines differ - expected: '218640057', found: ''

Test #24:

score: 0
Wrong Answer
time: 1063ms
memory: 92804kb

input:

200000 20
11 4 7 18 16 15 15 18 11 2 4 1 17 18 6 9 19 12 2 14 8 6 10 4 15 16 17 13 18 1 15 18 15 9 1...

output:


result:

wrong answer 1st lines differ - expected: '438860874', found: ''

Test #25:

score: 0
Wrong Answer
time: 1052ms
memory: 92804kb

input:

200000 20
5 3 18 11 17 13 14 19 0 0 1 3 4 13 8 1 15 7 15 2 12 8 3 15 8 1 4 8 7 5 9 16 9 16 0 14 2 16...

output:


result:

wrong answer 1st lines differ - expected: '739309565', found: ''