結果
問題 |
No.2758 RDQ
|
ユーザー |
👑 |
提出日時 | 2024-05-05 14:02:31 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 645 ms / 2,000 ms |
コード長 | 717 bytes |
コンパイル時間 | 152 ms |
コンパイル使用メモリ | 82,180 KB |
実行使用メモリ | 202,300 KB |
最終ジャッジ日時 | 2024-12-20 15:35:32 |
合計ジャッジ時間 | 11,816 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 |
ソースコード
import bisect M = 100000 R = 330 def enum_divisors(x): res = [] for i in range(1, R+1): if x % i == 0: square = i * i if x > square: res.extend([i, x // i]) elif x == square: res.append(i) else: break return res n, q = map(int, input().split()) a = list(map(int, input().split())) cnt = [[] for _ in range(M + 1)] for i in range(n): divisors = enum_divisors(a[i]) for x in divisors: cnt[x].append(i) for _ in range(q): l, r, k = map(int, input().split()) l -= 1 r -= 1 li = bisect.bisect_left(cnt[k], l) ri = bisect.bisect_right(cnt[k], r) print(ri - li)