結果

問題 No.1742 Binary Indexed Train
ユーザー Shirotsume
提出日時 2021-10-22 20:23:55
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
AC  
実行時間 801 ms / 3,000 ms
コード長 599 bytes
コンパイル時間 201 ms
コンパイル使用メモリ 12,672 KB
実行使用メモリ 32,256 KB
最終ジャッジ日時 2024-11-25 11:01:08
合計ジャッジ時間 16,711 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 32
権限があれば一括ダウンロードができます

ソースコード

diff #

def solve(n, q, st):
    answer = []
    for s, t in st:
        if 0 <= s < t <= 2 ** n:
            pass
        else:
            raise Exception
        ans = 0
        k=1<<n
        while not((t-1)//k > (s-1)//k):
            k>>=1
        mid=k*((s+k-1)//k)
        ans = bin(mid - s).count('1') + bin(t - mid).count('1')
        answer.append(ans)
    return answer


n, q = map(int,input().split())

if 1 <= n <= 60 and 1 <= q <= 10 ** 5:
    pass
else:
    raise Exception
    
st = [list(map(int,input().split())) for _ in range(q)]
answer = solve(n, q, st)

for i in answer:
    print(i)
0