提出 #73241227
ソースコード 拡げる
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
from collections import Counter
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():
m,n = mii()
p = [lii() for i in range(n)]
p.sort()
sl = SortedList()
l = 0
for i in range(1,m+1):
while l<n and p[l][0]<=i:
sl.add(p[l][1])
l+=1
if sl:
x = sl.pop(0)
if x<i:
print("No")
return
print("Yes" if not sl else "No")
t = 1
# t = ii()
for _ in range(t):
solve()
提出情報
| 提出日時 | |
|---|---|
| 問題 | D - 駐車場の割り当て |
| ユーザ | xiaoe |
| 言語 | Python (PyPy 3.11-v7.3.20) |
| 得点 | 400 |
| コード長 | 8559 Byte |
| 結果 | AC |
| 実行時間 | 307 ms |
| メモリ | 122368 KiB |
ジャッジ結果
| セット名 | Sample | All | ||||
|---|---|---|---|---|---|---|
| 得点 / 配点 | 0 / 0 | 400 / 400 | ||||
| 結果 |
|
|
| セット名 | テストケース |
|---|---|
| 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, in73.txt, in74.txt, in75.txt, in76.txt, in77.txt |
| ケース名 | 結果 | 実行時間 | メモリ |
|---|---|---|---|
| in01.txt | AC | 69 ms | 95096 KiB |
| in02.txt | AC | 70 ms | 95236 KiB |
| in03.txt | AC | 70 ms | 95236 KiB |
| in04.txt | AC | 70 ms | 95168 KiB |
| in05.txt | AC | 70 ms | 95048 KiB |
| in06.txt | AC | 70 ms | 95376 KiB |
| in07.txt | AC | 73 ms | 101532 KiB |
| in08.txt | AC | 84 ms | 109432 KiB |
| in09.txt | AC | 231 ms | 120192 KiB |
| in10.txt | AC | 70 ms | 95108 KiB |
| in11.txt | AC | 281 ms | 121336 KiB |
| in12.txt | AC | 291 ms | 120824 KiB |
| in13.txt | AC | 73 ms | 100672 KiB |
| in14.txt | AC | 73 ms | 100764 KiB |
| in15.txt | AC | 74 ms | 101968 KiB |
| in16.txt | AC | 130 ms | 120968 KiB |
| in17.txt | AC | 242 ms | 120868 KiB |
| in18.txt | AC | 307 ms | 121584 KiB |
| in19.txt | AC | 278 ms | 120848 KiB |
| in20.txt | AC | 134 ms | 121336 KiB |
| in21.txt | AC | 229 ms | 120164 KiB |
| in22.txt | AC | 129 ms | 120908 KiB |
| in23.txt | AC | 242 ms | 120744 KiB |
| in24.txt | AC | 176 ms | 121508 KiB |
| in25.txt | AC | 274 ms | 122024 KiB |
| in26.txt | AC | 242 ms | 120792 KiB |
| in27.txt | AC | 251 ms | 120764 KiB |
| in28.txt | AC | 70 ms | 95196 KiB |
| in29.txt | AC | 70 ms | 95376 KiB |
| in30.txt | AC | 70 ms | 95124 KiB |
| in31.txt | AC | 70 ms | 95188 KiB |
| in32.txt | AC | 70 ms | 94812 KiB |
| in33.txt | AC | 73 ms | 101048 KiB |
| in34.txt | AC | 70 ms | 95180 KiB |
| in35.txt | AC | 70 ms | 95348 KiB |
| in36.txt | AC | 69 ms | 95048 KiB |
| in37.txt | AC | 70 ms | 95112 KiB |
| in38.txt | AC | 70 ms | 95240 KiB |
| in39.txt | AC | 70 ms | 95068 KiB |
| in40.txt | AC | 70 ms | 95288 KiB |
| in41.txt | AC | 70 ms | 94812 KiB |
| in42.txt | AC | 69 ms | 95400 KiB |
| in43.txt | AC | 70 ms | 95128 KiB |
| in44.txt | AC | 70 ms | 95112 KiB |
| in45.txt | AC | 78 ms | 105244 KiB |
| in46.txt | AC | 94 ms | 109592 KiB |
| in47.txt | AC | 70 ms | 95168 KiB |
| in48.txt | AC | 70 ms | 95168 KiB |
| in49.txt | AC | 70 ms | 95376 KiB |
| in50.txt | AC | 70 ms | 95360 KiB |
| in51.txt | AC | 181 ms | 121452 KiB |
| in52.txt | AC | 135 ms | 121132 KiB |
| in53.txt | AC | 281 ms | 121980 KiB |
| in54.txt | AC | 275 ms | 122044 KiB |
| in55.txt | AC | 293 ms | 121680 KiB |
| in56.txt | AC | 121 ms | 120128 KiB |
| in57.txt | AC | 217 ms | 120028 KiB |
| in58.txt | AC | 128 ms | 120248 KiB |
| in59.txt | AC | 178 ms | 120352 KiB |
| in60.txt | AC | 292 ms | 122368 KiB |
| in61.txt | AC | 153 ms | 120988 KiB |
| in62.txt | AC | 120 ms | 120012 KiB |
| in63.txt | AC | 70 ms | 95248 KiB |
| in64.txt | AC | 70 ms | 95272 KiB |
| in65.txt | AC | 70 ms | 95196 KiB |
| in66.txt | AC | 70 ms | 95112 KiB |
| in67.txt | AC | 70 ms | 95272 KiB |
| in68.txt | AC | 70 ms | 95416 KiB |
| in69.txt | AC | 70 ms | 95060 KiB |
| in70.txt | AC | 70 ms | 95248 KiB |
| in71.txt | AC | 70 ms | 95136 KiB |
| in72.txt | AC | 70 ms | 95084 KiB |
| in73.txt | AC | 70 ms | 95136 KiB |
| in74.txt | AC | 70 ms | 95136 KiB |
| in75.txt | AC | 70 ms | 95208 KiB |
| in76.txt | AC | 70 ms | 95036 KiB |
| in77.txt | AC | 169 ms | 120984 KiB |
| sample01.txt | AC | 70 ms | 95128 KiB |
| sample02.txt | AC | 70 ms | 94812 KiB |
| sample03.txt | AC | 70 ms | 95264 KiB |