提交记录 16773


用户 题目 状态 得分 用时 内存 语言 代码长度
Saisyc 1002. 测测你的多项式乘法 Accepted 100 251.053 ms 32400 KB C++ 1.49 KB
提交时间 评测时间
2021-10-18 01:19:45 2021-10-18 01:19:47
#include <algorithm>

const int N = 1 << 21; const int _N = N >> 1;
const int p = 81 << 21 | 1;

inline int pow_modp(int a, int b) { int x = 1; for(; b; a = (long long)a * a % p, b >>= 1) if(b & 1) x = (long long)x * a % p; return x; }

unsigned ntt_sup[N];
inline void ntt(auto a[]) {
	auto b = ntt_sup, j = a, _j = a; int _n = N >> 1, i, k, _k, w, _w;
	for(i = 1, w = 154249541; i < N; i <<= 1, w = (long long)w * w % p, std :: swap(a, b))
		for(k = 0, j = a, _j = a + _n, _w = 1; k != N; k += i, _w = (long long)_w * w % p)
			for(_k = k, k += i; _k != k; ++j, ++_j, ++_k)
				b[_k] = *j + *_j < p ? *j + *_j : *j + *_j - p,
				b[_k + i] = (long long)(*j - *_j + p) * _w % p;
	std :: copy(a, a + N, b);
}
inline void intt(auto a[]) {
	auto b = ntt_sup, j = a, _j = a; int _n = N >> 1, i, k, _k, w, _w;
	for(i = 1, w = 5446305; i < N; i <<= 1, w = (long long)w * w % p, std :: swap(a, b))
		for(k = 0, j = a, _j = a + _n, _w = 1; k != N; k += i, _w = (long long)_w * w % p)
			for(_k = k, k += i; _k != k; ++j, ++_j, ++_k)
				b[_k] = *j + *_j < p ? *j + *_j : *j + *_j - p,
				b[_k + i] = (long long)(*j - *_j + p) * _w % p;
	std :: copy(a, a + N, b);
}

unsigned a[N], b[N];
void poly_multiply(unsigned *aa, int n, unsigned *bb, int m, unsigned *c) {
	std :: copy(aa, aa + n + 1, a), std :: copy(bb, bb + m + 1, b);
	m += n; for(n = 1; n <= m; n <<= 1); ++m;
	ntt(a), ntt(b); for(int i = 0; i < n; ++i) a[i] = (long long)a[i] * b[i] % p; intt(a);
	for(int i = 0; i < m; ++i) c[i] = (long long)a[i] * 169869232 % p;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #1251.053 ms31 MB + 656 KBAcceptedScore: 100


Judge Duck Online | 评测鸭在线
Server Time: 2026-03-18 16:12:39 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠