Submission #73156306
Source Code Expand
import sys
input = lambda: sys.stdin.readline().rstrip()
ii = lambda: int(input())
mii = lambda: map(int, input().split())
lii = lambda: list(mii())
MOD = 10**9+7
inf = 1<<64
class SortedList:
def __init__(self, iterable=None, _load=200):
"""Initialize sorted list instance."""
if iterable is None:
iterable = []
values = sorted(iterable)
self._len = _len = len(values)
self._load = _load
self._lists = _lists = [values[i:i + _load]
for i in range(0, _len, _load)]
self._list_lens = [len(_list) for _list in _lists]
self._min_s = [_list[0] for _list in _lists]
self._fen_tree = []
self._rebuild = True
def _fen_build(self):
"""Build a fenwick tree instance."""
self._fen_tree[:] = self._list_lens
_fen_tree = self._fen_tree
for i in range(len(_fen_tree)):
if i | i + 1 < len(_fen_tree):
_fen_tree[i | i + 1] += _fen_tree[i]
self._rebuild = False
def _fen_update(self, index, value):
"""Update `fen_tree[index] += value`."""
if not self._rebuild:
_fen_tree = self._fen_tree
while index < len(_fen_tree):
_fen_tree[index] += value
index |= index + 1
def _fen_query(self, end):
"""Return `sum(_fen_tree[:end])`."""
if self._rebuild:
self._fen_build()
_fen_tree = self._fen_tree
x = 0
while end:
x += _fen_tree[end - 1]
end &= end - 1
return x
def _fen_findkth(self, k):
"""Return a pair of (the largest `idx` such that `sum(_fen_tree[:idx]) <= k`, `k - sum(_fen_tree[:idx])`)."""
_list_lens = self._list_lens
if k < _list_lens[0]:
return 0, k
if k >= self._len - _list_lens[-1]:
return len(_list_lens) - 1, k + _list_lens[-1] - self._len
if self._rebuild:
self._fen_build()
_fen_tree = self._fen_tree
idx = -1
for d in reversed(range(len(_fen_tree).bit_length())):
right_idx = idx + (1 << d)
if right_idx < len(_fen_tree) and k >= _fen_tree[right_idx]:
idx = right_idx
k -= _fen_tree[idx]
return idx + 1, k
def _delete(self, pos, idx):
"""Delete value at the given `(pos, idx)`."""
_lists = self._lists
_mins = self._min_s
_list_lens = self._list_lens
self._len -= 1
self._fen_update(pos, -1)
del _lists[pos][idx]
_list_lens[pos] -= 1
if _list_lens[pos]:
_mins[pos] = _lists[pos][0]
else:
del _lists[pos]
del _list_lens[pos]
del _mins[pos]
self._rebuild = True
def _loc_left(self, value):
"""Return an index pair that corresponds to the first position of `value` in the sorted list."""
if not self._len:
return 0, 0
_lists = self._lists
_mins = self._min_s
lo, pos = -1, len(_lists) - 1
while lo + 1 < pos:
mi = (lo + pos) >> 1
if value <= _mins[mi]:
pos = mi
else:
lo = mi
if pos and value <= _lists[pos - 1][-1]:
pos -= 1
_list = _lists[pos]
lo, idx = -1, len(_list)
while lo + 1 < idx:
mi = (lo + idx) >> 1
if value <= _list[mi]:
idx = mi
else:
lo = mi
return pos, idx
def _loc_right(self, value):
"""Return an index pair that corresponds to the last position of `value` in the sorted list."""
if not self._len:
return 0, 0
_lists = self._lists
_mins = self._min_s
pos, hi = 0, len(_lists)
while pos + 1 < hi:
mi = (pos + hi) >> 1
if value < _mins[mi]:
hi = mi
else:
pos = mi
_list = _lists[pos]
lo, idx = -1, len(_list)
while lo + 1 < idx:
mi = (lo + idx) >> 1
if value < _list[mi]:
idx = mi
else:
lo = mi
return pos, idx
def add(self, value):
"""Add `value` to sorted list."""
_load = self._load
_lists = self._lists
_mins = self._min_s
_list_lens = self._list_lens
self._len += 1
if _lists:
pos, idx = self._loc_right(value)
self._fen_update(pos, 1)
_list = _lists[pos]
_list.insert(idx, value)
_list_lens[pos] += 1
_mins[pos] = _list[0]
if _load + _load < len(_list):
_lists.insert(pos + 1, _list[_load:])
_list_lens.insert(pos + 1, len(_list) - _load)
_mins.insert(pos + 1, _list[_load])
_list_lens[pos] = _load
del _list[_load:]
self._rebuild = True
else:
_lists.append([value])
_mins.append(value)
_list_lens.append(1)
self._rebuild = True
def discard(self, value):
"""Remove `value` from sorted list if it is a member."""
_lists = self._lists
if _lists:
pos, idx = self._loc_right(value)
if idx and _lists[pos][idx - 1] == value:
self._delete(pos, idx - 1)
def remove(self, value):
"""Remove `value` from sorted list; `value` must be a member."""
_len = self._len
self.discard(value)
if _len == self._len:
raise ValueError('{0!r} not in list'.format(value))
def pop(self, index=-1):
"""Remove and return value at `index` in sorted list."""
pos, idx = self._fen_findkth(self._len + index if index < 0 else index)
value = self._lists[pos][idx]
self._delete(pos, idx)
return value
def bisect_left(self, value):
"""Return the first index to insert `value` in the sorted list."""
pos, idx = self._loc_left(value)
return self._fen_query(pos) + idx
def bisect_right(self, value):
"""Return the last index to insert `value` in the sorted list."""
pos, idx = self._loc_right(value)
return self._fen_query(pos) + idx
def count(self, value):
"""Return number of occurrences of `value` in the sorted list."""
return self.bisect_right(value) - self.bisect_left(value)
def __len__(self):
"""Return the size of the sorted list."""
return self._len
def __getitem__(self, index):
"""Lookup value at `index` in sorted list."""
pos, idx = self._fen_findkth(self._len + index if index < 0 else index)
return self._lists[pos][idx]
def __delitem__(self, index):
"""Remove value at `index` from sorted list."""
pos, idx = self._fen_findkth(self._len + index if index < 0 else index)
self._delete(pos, idx)
def __contains__(self, value):
"""Return true if `value` is an element of the sorted list."""
_lists = self._lists
if _lists:
pos, idx = self._loc_left(value)
return idx < len(_lists[pos]) and _lists[pos][idx] == value
return False
def __iter__(self):
"""Return an iterator over the sorted list."""
return (value for _list in self._lists for value in _list)
def __reversed__(self):
"""Return a reverse iterator over the sorted list."""
return (value for _list in reversed(self._lists)
for value in reversed(_list))
def __repr__(self):
"""Return strings representation of sorted list."""
return 'SortedList({0})'.format(list(self))
def solve():
n,k = mii()
a = lii()
l = 0
sl = SortedList()
mx = -inf
for r,x in enumerate(a):
sl.add(x)
if r-l+1>k:
sl.remove(a[l])
l+=1
mx = max(mx,sl[-1]-sl[0])
print(mx)
t = 1
# t = ii()
for _ in range(t):
solve()
Submission Info
| Submission Time | |
|---|---|
| Task | E - Temperature Fluctuation Range |
| User | xiaoe |
| Language | Python (PyPy 3.11-v7.3.20) |
| Score | 466 |
| Code Size | 8419 Byte |
| Status | AC |
| Exec Time | 236 ms |
| Memory | 142008 KiB |
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 466 / 466 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | sample01.txt, sample02.txt, sample03.txt |
| All | sample01.txt, sample02.txt, sample03.txt, in01.txt, in02.txt, in03.txt, in04.txt, in05.txt, in06.txt, in07.txt, in08.txt, in09.txt, in10.txt, in11.txt, in12.txt, in13.txt, in14.txt, in15.txt, in16.txt, in17.txt, in18.txt, in19.txt, in20.txt, in21.txt, in22.txt, in23.txt, in24.txt, in25.txt, in26.txt, in27.txt, in28.txt, in29.txt, in30.txt, in31.txt, in32.txt, in33.txt, in34.txt, in35.txt, in36.txt, in37.txt, in38.txt, in39.txt, in40.txt, in41.txt, in42.txt, in43.txt, in44.txt, in45.txt, in46.txt, in47.txt, in48.txt, in49.txt, in50.txt, in51.txt, in52.txt, in53.txt, in54.txt, in55.txt, in56.txt, in57.txt, in58.txt, in59.txt, in60.txt, in61.txt, in62.txt, in63.txt, in64.txt, in65.txt, in66.txt, in67.txt, in68.txt, in69.txt, in70.txt, in71.txt, in72.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| in01.txt | AC | 58 ms | 81176 KiB |
| in02.txt | AC | 59 ms | 81132 KiB |
| in03.txt | AC | 59 ms | 81276 KiB |
| in04.txt | AC | 59 ms | 81312 KiB |
| in05.txt | AC | 59 ms | 81152 KiB |
| in06.txt | AC | 60 ms | 81308 KiB |
| in07.txt | AC | 59 ms | 81144 KiB |
| in08.txt | AC | 59 ms | 81192 KiB |
| in09.txt | AC | 58 ms | 81260 KiB |
| in10.txt | AC | 236 ms | 141196 KiB |
| in11.txt | AC | 223 ms | 140776 KiB |
| in12.txt | AC | 216 ms | 140700 KiB |
| in13.txt | AC | 166 ms | 140684 KiB |
| in14.txt | AC | 140 ms | 141124 KiB |
| in15.txt | AC | 139 ms | 140696 KiB |
| in16.txt | AC | 153 ms | 141236 KiB |
| in17.txt | AC | 152 ms | 141424 KiB |
| in18.txt | AC | 58 ms | 80884 KiB |
| in19.txt | AC | 123 ms | 136840 KiB |
| in20.txt | AC | 196 ms | 140780 KiB |
| in21.txt | AC | 184 ms | 141228 KiB |
| in22.txt | AC | 153 ms | 141144 KiB |
| in23.txt | AC | 169 ms | 141484 KiB |
| in24.txt | AC | 166 ms | 140620 KiB |
| in25.txt | AC | 173 ms | 142008 KiB |
| in26.txt | AC | 229 ms | 140776 KiB |
| in27.txt | AC | 201 ms | 140652 KiB |
| in28.txt | AC | 178 ms | 140708 KiB |
| in29.txt | AC | 58 ms | 81180 KiB |
| in30.txt | AC | 58 ms | 81180 KiB |
| in31.txt | AC | 58 ms | 81316 KiB |
| in32.txt | AC | 58 ms | 81200 KiB |
| in33.txt | AC | 59 ms | 81372 KiB |
| in34.txt | AC | 58 ms | 81308 KiB |
| in35.txt | AC | 59 ms | 81572 KiB |
| in36.txt | AC | 232 ms | 139848 KiB |
| in37.txt | AC | 222 ms | 139876 KiB |
| in38.txt | AC | 58 ms | 81236 KiB |
| in39.txt | AC | 58 ms | 81308 KiB |
| in40.txt | AC | 70 ms | 93016 KiB |
| in41.txt | AC | 91 ms | 109048 KiB |
| in42.txt | AC | 58 ms | 81312 KiB |
| in43.txt | AC | 58 ms | 81364 KiB |
| in44.txt | AC | 58 ms | 81148 KiB |
| in45.txt | AC | 59 ms | 81328 KiB |
| in46.txt | AC | 225 ms | 141372 KiB |
| in47.txt | AC | 210 ms | 140708 KiB |
| in48.txt | AC | 223 ms | 141088 KiB |
| in49.txt | AC | 225 ms | 140716 KiB |
| in50.txt | AC | 211 ms | 140904 KiB |
| in51.txt | AC | 230 ms | 139376 KiB |
| in52.txt | AC | 224 ms | 140764 KiB |
| in53.txt | AC | 231 ms | 139968 KiB |
| in54.txt | AC | 223 ms | 139960 KiB |
| in55.txt | AC | 58 ms | 81136 KiB |
| in56.txt | AC | 59 ms | 81196 KiB |
| in57.txt | AC | 58 ms | 81156 KiB |
| in58.txt | AC | 58 ms | 81024 KiB |
| in59.txt | AC | 58 ms | 81312 KiB |
| in60.txt | AC | 59 ms | 81148 KiB |
| in61.txt | AC | 58 ms | 81004 KiB |
| in62.txt | AC | 58 ms | 81412 KiB |
| in63.txt | AC | 217 ms | 137480 KiB |
| in64.txt | AC | 59 ms | 81200 KiB |
| in65.txt | AC | 59 ms | 81316 KiB |
| in66.txt | AC | 59 ms | 81024 KiB |
| in67.txt | AC | 59 ms | 81184 KiB |
| in68.txt | AC | 59 ms | 81308 KiB |
| in69.txt | AC | 59 ms | 81148 KiB |
| in70.txt | AC | 59 ms | 81316 KiB |
| in71.txt | AC | 59 ms | 81156 KiB |
| in72.txt | AC | 219 ms | 141228 KiB |
| sample01.txt | AC | 58 ms | 81208 KiB |
| sample02.txt | AC | 59 ms | 81412 KiB |
| sample03.txt | AC | 59 ms | 81412 KiB |