Submission #71311451
Source Code Expand
import sys
import string
import math
import bisect
import os
#import random
import heapq
import operator
from io import BytesIO, IOBase
from heapq import heappop,heappush
from functools import lru_cache,cache
from collections import deque,defaultdict,Counter,OrderedDict
from itertools import permutations,combinations
from array import array
INF = float('inf')
BUFSIZE = 8192
class FastIO(IOBase):
newlines = 0
def __init__(self, file):
self._file = file
self._fd = file.fileno()
self.buffer = BytesIO()
self.writable = "x" in file.mode or "r" not in file.mode
self.write = self.buffer.write if self.writable else None
def read(self):
while True:
b = os.read(self._fd, max(os.fstat(self._fd).st_size, BUFSIZE))
if not b:
break
ptr = self.buffer.tell()
self.buffer.seek(0, 2), self.buffer.write(b), self.buffer.seek(ptr)
self.newlines = 0
return self.buffer.read()
def readline(self):
while self.newlines == 0:
b = os.read(self._fd, max(os.fstat(self._fd).st_size, BUFSIZE))
self.newlines = b.count(b"\n") + (not b)
ptr = self.buffer.tell()
self.buffer.seek(0, 2), self.buffer.write(b), self.buffer.seek(ptr)
self.newlines -= 1
return self.buffer.readline()
def flush(self):
if self.writable:
os.write(self._fd, self.buffer.getvalue())
self.buffer.truncate(0), self.buffer.seek(0)
class IOWrapper(IOBase):
def __init__(self, file):
self.buffer = FastIO(file)
self.flush = self.buffer.flush
self.writable = self.buffer.writable
self.write = lambda s: self.buffer.write(s.encode("ascii"))
self.read = lambda: self.buffer.read().decode("ascii")
self.readline = lambda: self.buffer.readline().decode("ascii")
sys.stdin, sys.stdout = IOWrapper(sys.stdin), IOWrapper(sys.stdout)
input = sys.stdin.buffer.readline
ask = lambda *x:print('?',*x,flush=True)
reply = lambda *x:print('!',*x,flush=True)
RI = lambda: int(sys.stdin.readline())
RF = lambda: float(sys.stdin.readline())
RS = lambda: sys.stdin.readline().strip()
RFF = lambda: map(float, sys.stdin.readline().split())
RII = lambda: map(int, sys.stdin.readline().split())
RSS = lambda: map(str, sys.stdin.readline().strip().split())
RIL = lambda: list(RII())
RFL = lambda: list(RFF())
RSL = lambda: list(RSS())
from types import GeneratorType
def bootstrap(f, stack=[]):
def wrappedfunc(*args, **kwargs):
if stack:
return f(*args, **kwargs)
else:
to = f(*args, **kwargs)
while True:
if type(to) is GeneratorType:
stack.append(to)
to = next(to)
else:
stack.pop()
if not stack:
break
to = stack[-1].send(to)
return to
return wrappedfunc
def main():
test = 1
for _ in range(test):
m = RI()
n = 2000
f = [[0]*(n+3) for i in range(n+3)]
query = []
for i in range(m):
u,d,l,r = RII()
query.append((u,d,l,r))
f[l][u] += 1
f[l][d+1] -= 1
f[r+1][u] -= 1
f[r+1][d+1] += 1
now = 0
for i in range(n+1):
for j in range(n+1):
f[i][j] += f[i-1][j]+f[i][j-1]-f[i-1][j-1]
if f[i][j]>=1:
now += 1
g = [[0]*(n+3) for i in range(n+3)]
for i in range(n+1):
for j in range(n+1):
g[i][j] = g[i-1][j]+g[i][j-1]-g[i-1][j-1]+(f[i][j]==1)
M = 2000*2000
for u,d,l,r in query:
ans = now-(g[r][d]-g[l-1][d]-g[r][u-1]+g[l-1][u-1])
print(M-ans)
if __name__ == '__main__':
main()
Submission Info
| Submission Time | |
|---|---|
| Task | D - Clouds |
| User | x3x3 |
| Language | Python (PyPy 3.11-v7.3.20) |
| Score | 425 |
| Code Size | 4135 Byte |
| Status | AC |
| Exec Time | 414 ms |
| Memory | 211276 KiB |
Judge Result
| Set Name | Sample | All | ||||
|---|---|---|---|---|---|---|
| Score / Max Score | 0 / 0 | 425 / 425 | ||||
| Status |
|
|
| Set Name | Test Cases |
|---|---|
| Sample | sample_01.txt |
| All | sample_01.txt, test_01.txt, test_02.txt, test_03.txt, test_04.txt, test_05.txt, test_06.txt, test_07.txt, test_08.txt, test_09.txt, test_10.txt, test_11.txt, test_12.txt, test_13.txt, test_14.txt, test_15.txt, test_16.txt, test_17.txt, test_18.txt, test_19.txt, test_20.txt, test_21.txt, test_22.txt, test_23.txt, test_24.txt, test_25.txt, test_26.txt, test_27.txt, test_28.txt, test_29.txt, test_30.txt, test_31.txt, test_32.txt, test_33.txt, test_34.txt, test_35.txt, test_36.txt, test_37.txt, test_38.txt, test_39.txt, test_40.txt, test_41.txt, test_42.txt, test_43.txt, test_44.txt, test_45.txt, test_46.txt, test_47.txt, test_48.txt, test_49.txt, test_50.txt, test_51.txt, test_52.txt, test_53.txt, test_54.txt, test_55.txt, test_56.txt, test_57.txt |
| Case Name | Status | Exec Time | Memory |
|---|---|---|---|
| sample_01.txt | AC | 208 ms | 175656 KiB |
| test_01.txt | AC | 213 ms | 175572 KiB |
| test_02.txt | AC | 364 ms | 211208 KiB |
| test_03.txt | AC | 276 ms | 208032 KiB |
| test_04.txt | AC | 278 ms | 207936 KiB |
| test_05.txt | AC | 277 ms | 207920 KiB |
| test_06.txt | AC | 298 ms | 208256 KiB |
| test_07.txt | AC | 279 ms | 207928 KiB |
| test_08.txt | AC | 231 ms | 176692 KiB |
| test_09.txt | AC | 270 ms | 187984 KiB |
| test_10.txt | AC | 292 ms | 195628 KiB |
| test_11.txt | AC | 267 ms | 188076 KiB |
| test_12.txt | AC | 279 ms | 190860 KiB |
| test_13.txt | AC | 210 ms | 175596 KiB |
| test_14.txt | AC | 241 ms | 177588 KiB |
| test_15.txt | AC | 228 ms | 175764 KiB |
| test_16.txt | AC | 215 ms | 175684 KiB |
| test_17.txt | AC | 254 ms | 184288 KiB |
| test_18.txt | AC | 288 ms | 186472 KiB |
| test_19.txt | AC | 210 ms | 175584 KiB |
| test_20.txt | AC | 212 ms | 175600 KiB |
| test_21.txt | AC | 212 ms | 175812 KiB |
| test_22.txt | AC | 217 ms | 176032 KiB |
| test_23.txt | AC | 209 ms | 175308 KiB |
| test_24.txt | AC | 251 ms | 183160 KiB |
| test_25.txt | AC | 234 ms | 177008 KiB |
| test_26.txt | AC | 248 ms | 182544 KiB |
| test_27.txt | AC | 234 ms | 176840 KiB |
| test_28.txt | AC | 222 ms | 175740 KiB |
| test_29.txt | AC | 211 ms | 175312 KiB |
| test_30.txt | AC | 220 ms | 175368 KiB |
| test_31.txt | AC | 320 ms | 201636 KiB |
| test_32.txt | AC | 223 ms | 175888 KiB |
| test_33.txt | AC | 348 ms | 208996 KiB |
| test_34.txt | AC | 367 ms | 209876 KiB |
| test_35.txt | AC | 349 ms | 208924 KiB |
| test_36.txt | AC | 351 ms | 208624 KiB |
| test_37.txt | AC | 351 ms | 209760 KiB |
| test_38.txt | AC | 357 ms | 209700 KiB |
| test_39.txt | AC | 355 ms | 210180 KiB |
| test_40.txt | AC | 354 ms | 209924 KiB |
| test_41.txt | AC | 351 ms | 208940 KiB |
| test_42.txt | AC | 351 ms | 210140 KiB |
| test_43.txt | AC | 368 ms | 210496 KiB |
| test_44.txt | AC | 414 ms | 211112 KiB |
| test_45.txt | AC | 354 ms | 210324 KiB |
| test_46.txt | AC | 351 ms | 209796 KiB |
| test_47.txt | AC | 357 ms | 210224 KiB |
| test_48.txt | AC | 390 ms | 211276 KiB |
| test_49.txt | AC | 374 ms | 211092 KiB |
| test_50.txt | AC | 349 ms | 209020 KiB |
| test_51.txt | AC | 344 ms | 208512 KiB |
| test_52.txt | AC | 341 ms | 209388 KiB |
| test_53.txt | AC | 351 ms | 209840 KiB |
| test_54.txt | AC | 345 ms | 210328 KiB |
| test_55.txt | AC | 345 ms | 208708 KiB |
| test_56.txt | AC | 342 ms | 208616 KiB |
| test_57.txt | AC | 346 ms | 208932 KiB |