提交记录 18016


用户 题目 状态 得分 用时 内存 语言 代码长度
Seniorious 1002. 测测你的多项式乘法 Accepted 100 187.408 ms 64452 KB C++11 2.87 KB
提交时间 评测时间
2022-09-08 16:21:20 2022-09-08 16:21:22
#include <bits/stdc++.h>

typedef unsigned uint;
typedef long long ll;
typedef unsigned long long ull;
typedef std::pair<int, int> pii;
const int iinf = 2147483647;
const ll llinf = 9223372036854775807ll;

const int N = 2100000;
const int Mod = 998244353;
typedef std::vector<int> Poly;

int pow(int a, int b, int m);

namespace Pol {
int add(int a, int b) { return (a += b) >= Mod ? a -= Mod : a; }
int sub(int a, int b) { return (a -= b) < 0 ? a += Mod : a; }
void inc(int &a, int b) { (a += b) >= Mod ? a -= Mod : a; }
void dec(int &a, int b) { (a -= b) < 0 ? a += Mod : a; }
int &reduce(int &x) { return x += x >> 31 & Mod; }
void init_Poly(int n = N);
void DIT(int *A, int lim);
void DIF(int *A, int lim);
Poly mult(const Poly &A, int n, const Poly &B, int m);
ull tmp[N];
int gw[N];
}  // namespace Pol

void poly_multiply(unsigned *a, int n, unsigned *b, int m, unsigned *c) {
  Pol::init_Poly();
  ++n, ++m;
  Poly F(n), G(m);
  for (int i = 0; i < n; ++i)
    F[i] = a[i];
  for (int i = 0; i < m; ++i)
    G[i] = b[i];
  Poly ans = Pol::mult(F, n, G, m);
  for (int i = 0; i < n + m - 1; ++i)
    c[i] = ans[i];
}

namespace Pol {
void DIT(int *A, int lim) {
  for (int l = 1; l != lim; l <<= 1) {
    int *k = A;
    for (int *g = gw; k != A + lim; k += (l << 1), ++g) {
      for (int *x = k; x != k + l; ++x) {
        int o = x[l];
        x[l] = 1ll * (*x + Mod - o) * *g % Mod, inc(*x, o);
      }
    }
  }
  int iv = pow(lim, Mod - 2, Mod);
  for (int i = 0; i != lim; ++i) A[i] = 1ll * A[i] * iv % Mod;
  std::reverse(A + 1, A + lim);
}
void DIF(int *A, int lim) {
  for (int i = 0; i != lim; ++i) tmp[i] = A[i];
  for (int l = lim / 2; l; l >>= 1) {
    ull *k = tmp;
    for (int *g = gw; k != tmp + lim; k += (l << 1), ++g) {
      for (ull *x = k; x != k + l; ++x) {
        int o = 1ll * x[l] * *g % Mod;
        x[l] = *x + Mod - o, *x += o;
      }
    }
  }
  for (int i = 0; i != lim; ++i) A[i] = tmp[i] % Mod;
}
Poly mult(const Poly &A, int n, const Poly &B, int m) {
  int lim = 1;
  while (lim < (n + m - 1))
    lim <<= 1;
  static int tA[N], tB[N];
  std::copy_n(A.begin(), n, tA), std::fill(tA + n, tA + lim, 0);
  std::copy_n(B.begin(), m, tB), std::fill(tB + m, tB + lim, 0);
  DIF(tA, lim), DIF(tB, lim);
  for (int i = 0; i < lim; ++i)
    tA[i] = 1ll * tA[i] * tB[i] % Mod;
  DIT(tA, lim);
  Poly ans(n + m - 1);
  std::copy_n(tA, n + m - 1, ans.begin());
  return ans;
}
void init_Poly(int n) {
  int t = 1;
  while ((1 << t) < n)
    ++t;
  t = std::min(t - 1, 21);
  gw[0] = 1, gw[1 << t] = pow(31, 1 << (21 - t), Mod);
  for (int i = t; i; --i)
    gw[1 << (i - 1)] = 1ll * gw[1 << i] * gw[1 << i] % Mod;
  for (int i = 1; i < (1 << t); ++i)
    gw[i] = 1ll * gw[i & (i - 1)] * gw[i & -i] % Mod;
}
}  // namespace Pol

int pow(int a, int b, int m) {
  int ans = 1, now = a;
  while (b) {
    if (b & 1) ans = 1ll * ans * now % m;
    now = 1ll * now * now % m;
    b >>= 1;
  }
  return ans;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #1187.408 ms62 MB + 964 KBAcceptedScore: 100


Judge Duck Online | 评测鸭在线
Server Time: 2024-11-23 05:23:50 | Loaded in 0 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠