結果
問題 |
No.206 数の積集合を求めるクエリ
|
ユーザー |
![]() |
提出日時 | 2021-04-27 20:49:00 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 545 ms / 7,000 ms |
コード長 | 524 bytes |
コンパイル時間 | 229 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 62,064 KB |
最終ジャッジ日時 | 2024-07-06 15:52:31 |
合計ジャッジ時間 | 17,084 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 28 |
ソースコード
import numpy as np fft = np.fft.rfft ifft = np.fft.irfft L, M, N = map(int, input().split()) A = np.array(input().split(), dtype=np.int32) B = np.array(input().split(), dtype=np.int32) Q = int(input()) Fa = np.zeros(N+1, dtype=np.int32) Fb = np.zeros(N+1, dtype=np.int32) Fa[A] = 1 Fb[B] = 1 sz = len(Fa) + len(Fb) - 1 fft_len = 1 << (sz - 1).bit_length() Ca = fft(Fa[::-1], fft_len) Cb = fft(Fb, fft_len) F = ifft(Ca * Cb, fft_len) F = np.rint(F).astype(np.int32) ans = F[N-Q+1:N+1].tolist() print(*ans[::-1], sep="\n")