結果

問題 No.2758 RDQ
ユーザー トミー
提出日時 2024-05-17 22:15:43
言語 PyPy3
(7.3.15)
結果
TLE  
実行時間 -
コード長 899 bytes
コンパイル時間 356 ms
コンパイル使用メモリ 82,240 KB
実行使用メモリ 771,264 KB
最終ジャッジ日時 2024-12-20 14:10:46
合計ジャッジ時間 53,416 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2 MLE * 1
other AC * 5 TLE * 6 MLE * 10
権限があれば一括ダウンロードができます

ソースコード

diff #

def query(l: int, r: int, k: int, a: list[int]) -> int:
    cnt = 0
    for i in range(l-1, r):
        if a[i] % k == 0:
            cnt += 1
    return cnt


def main() -> None:
    # すべてのkに対して累積和?
    n, q = map(int, input().split())
    a = list(map(int, input().split()))
    result = []
    lrk = []
    d: dict = {}
    for i in range(q):
        l, r, k = map(int, input().split())
        lrk.append((l, r, k))
    for i in range(len(lrk)):
        k = lrk[i][2]
        l = [0]
        for j in range(len(a)):
            if len(l) == 0:
                l.append(1 if a[j] % k == 0 else 0)
            else:
                l.append(l[-1]+(1 if a[j] % k == 0 else 0))
        d[k] = l
    # print(d)
    for i in range(len(lrk)):
        l, r, k = lrk[i]
        result.append(d[k][r]-d[k][l-1])
    print(*result, sep="\n")


if __name__ == "__main__":
    main()
0