結果
| 問題 |
No.1096 Range Sums
|
| コンテスト | |
| ユーザー |
c-yan
|
| 提出日時 | 2020-06-27 06:58:00 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,083 bytes |
| コンパイル時間 | 107 ms |
| コンパイル使用メモリ | 12,800 KB |
| 実行使用メモリ | 188,296 KB |
| 最終ジャッジ日時 | 2024-07-05 08:50:22 |
| 合計ジャッジ時間 | 10,040 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 WA * 2 |
| other | AC * 1 WA * 11 |
ソースコード
from itertools import accumulate
class SparseTable():
_data = None
_lookup = None
def __init__(self, a):
data = []
lookup = []
b = 0
while (1 << b) <= len(a):
b += 1
for _ in range(b):
data.append([0] * (1 << b))
data[0][:len(a)] = a
for i in range(1, b):
j = 0
di = data[i]
di1 = data[i - 1]
while j + (1 << i) <= (1 << b):
di[j] = di1[j] + di1[j + (1 << (i - 1))]
j += 1
lookup = [0] * (len(a) + 1)
for i in range(2, len(lookup)):
lookup[i] = lookup[i >> 1] + 1
self._data = data
self._lookup = lookup
def query(self, start, stop):
b = self._lookup[stop - start]
db = self._data[b]
return db[start] + db[stop - (1 << b)]
N, *A = map(int, open(0).read().split())
a = list(accumulate(A))
st = SparseTable(a)
result = 0
result += st.query(0, N)
for i in range(1, N):
result += st.query(i, N) - a[i - 1] * (N - i)
print(result)
c-yan