CP-Algorithms Library

This documentation is automatically generated by competitive-verifier/competitive-verifier

View the Project on GitHub cp-algorithms/cp-algorithms-aux

:heavy_check_mark: Multidimensional Convolution (Truncated) (verify/poly/multivar.test.cpp)

Depends on

Code

// @brief Multidimensional Convolution (Truncated)
#define PROBLEM "https://judge.yosupo.jp/problem/multivariate_convolution"
#pragma GCC optimize("O3,unroll-loops")
#define CP_ALGO_CHECKPOINT
#pragma GCC target("avx2")
#include <bits/stdc++.h>
//#include "blazingio/blazingio.min.hpp"
#include "cp-algo/math/multivar.hpp"

using namespace std;
using namespace cp_algo::math::fft;

const int mod = 998244353;
using base = cp_algo::math::modint<mod>;

void solve() {
    int k;
    cin >> k;
    cp_algo::big_vector<size_t> N(k);
    for(auto &n: N) cin >> n;
    multivar<base> a(N), b(N);
    a.read();
    b.read();
    a.mul(b);
    a.print();
    cp_algo::checkpoint<1>();
}

signed main() {
    //freopen("input.txt", "r", stdin);
    ios::sync_with_stdio(0);
    cin.tie(0);
    solve();
}
Traceback (most recent call last):
  File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj_resolve/resolver.py", line 181, in resolve
    bundled_code = language.bundle(path, basedir=basedir)
                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/verify/languages/cplusplus.py", line 252, in bundle
    bundler.update(path)
  File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/verify/languages/cplusplus_bundle.py", line 327, in update
    assert len(lines) == len(uncommented_lines)
           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
AssertionError

Test cases

Env Name Status Elapsed Memory
g++ dim1_00 :heavy_check_mark: AC 65 ms 40 MB
g++ dim1_01 :heavy_check_mark: AC 66 ms 40 MB
g++ dim2_00 :heavy_check_mark: AC 83 ms 56 MB
g++ dim2_01 :heavy_check_mark: AC 83 ms 57 MB
g++ example_00 :heavy_check_mark: AC 5 ms 4 MB
g++ example_01 :heavy_check_mark: AC 4 ms 4 MB
g++ example_02 :heavy_check_mark: AC 4 ms 4 MB
g++ k0_00 :heavy_check_mark: AC 4 ms 4 MB
g++ k0_01 :heavy_check_mark: AC 4 ms 4 MB
g++ max_random_00 :heavy_check_mark: AC 167 ms 136 MB
g++ max_random_01 :heavy_check_mark: AC 176 ms 136 MB
g++ small_00 :heavy_check_mark: AC 5 ms 4 MB
g++ small_01 :heavy_check_mark: AC 4 ms 4 MB
g++ threes_00 :heavy_check_mark: AC 376 ms 251 MB
g++ threes_01 :heavy_check_mark: AC 322 ms 234 MB
g++ twos_00 :heavy_check_mark: AC 563 ms 319 MB
g++ twos_01 :heavy_check_mark: AC 258 ms 153 MB
Back to top page