提交记录 21744


用户 题目 状态 得分 用时 内存 语言 代码长度
CTZss 1002i. 【模板题】多项式乘法 Accepted 100 79.527 ms 8732 KB C++ 2.11 KB
提交时间 评测时间
2024-05-10 09:15:25 2024-05-10 09:15:30
#include <algorithm>
#include <vector>
#include <cstdio>
#include <string.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const ll Q = 998244353, G = 3;
const int MaxN = 6e5 + 7;
ll qpow(ll a,int n)
{
    ll bas = 1;
    while (n)
    {
        if (n & 1)
            (bas *= a) %= Q;
        (a *= a) %= Q, n >>= 1;
    }
    return bas;
}
ll inv(ll a) { return qpow(a, Q - 2); }
const ll ivG = inv(G);
int tr[MaxN];
ull t1[MaxN], t2[MaxN], t3[MaxN];
inline void tpre(int len)
{
    int lg = __lg(len);
    for(int i = 1; i < len; ++i)
        tr[i] = (tr[i >> 1] >> 1) | ((i & 1) << (lg - 1));
}
template<class Tp>
inline void clear(Tp *f, int len) { memset(f, 0, sizeof(Tp) * len); }
void NTT(int *f,bool tp,int len)
{
    tpre(len);
    t2[0] = 1;
    for (int i = 0; i < len; ++i)
        t1[i] = f[tr[i]];
    for (int i = 1; i < len; i <<= 1)
    {
        ull wn = qpow(tp ? G : ivG, (Q - 1) / (i + i));
        for (int j = 1; j < i; ++j)
            t2[j] = t2[j - 1] * wn % Q;
        for (int j = 0; j < len; j += i)
            for (int k = 0; k < i; ++k)
            {
                ull t = t1[i | j | k] * t2[k] % Q;
                t1[i | j | k] = t1[j | k] + Q - t;
                t1[j | k] += t;
            }
        if (i == (1 << 10))
            for (int j = 0; j < len; ++j)
                t1[j] %= Q;
    }
    if (tp)
        for (int i = 0; i < len; ++i)
            f[i] = t1[i] % Q;
    else
    {
        ull ivl = inv(len);
        for (int i = 0; i < len; ++i)
            f[i] = t1[i] % Q * ivl % Q;
    }
    clear(t1, len), clear(t2, len);
}
void inver(int *h, int *f, int len)
{
}
int f[MaxN], g[MaxN];
int main()
{
    int m1, m2, i;
    scanf("%d%d", &m1, &m2);
    ++m1,++m2;
    for (i = 0; i < m1; ++i)
        scanf("%d", f + i);
    for (i = 0; i < m2; ++i)
        scanf("%d", g + i);
    int len = 1;
    while (len < m1 + m2 - 1)
        len <<= 1;
    NTT(f, 1, len), NTT(g, 1, len);
    for (i = 0; i < len; ++i)
        f[i] = 1ll * f[i] * g[i] % Q;
    NTT(f, 0, len);
    for (i = 0; i < m1 + m2 - 1; ++i)
        printf("%d%c", f[i], " \n"[i == m1 + m2 - 2]);
    return 0;
}

CompilationN/AN/ACompile OKScore: N/A

Subtask #1 Testcase #114.83 us36 KBAcceptedScore: 100

Subtask #1 Testcase #279.06 ms8 MB + 460 KBAcceptedScore: 0

Subtask #1 Testcase #336.131 ms3 MB + 824 KBAcceptedScore: 0

Subtask #1 Testcase #436.158 ms3 MB + 812 KBAcceptedScore: 0

Subtask #1 Testcase #513.42 us36 KBAcceptedScore: 0

Subtask #1 Testcase #612.6 us36 KBAcceptedScore: 0

Subtask #1 Testcase #711.38 us36 KBAcceptedScore: 0

Subtask #1 Testcase #871.436 ms8 MB + 192 KBAcceptedScore: 0

Subtask #1 Testcase #971.737 ms8 MB + 192 KBAcceptedScore: 0

Subtask #1 Testcase #1064.118 ms7 MB + 948 KBAcceptedScore: 0

Subtask #1 Testcase #1179.527 ms8 MB + 540 KBAcceptedScore: 0

Subtask #1 Testcase #1279.126 ms7 MB + 420 KBAcceptedScore: 0

Subtask #1 Testcase #1310.52 us32 KBAcceptedScore: 0


Judge Duck Online | 评测鸭在线
Server Time: 2025-07-18 02:43:32 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠