← Back to List

19766번: Доставка футболок ↗

Solutions

Python 3
874 B | 786 chars
import sys
from math import sqrt, pi, sin, factorial, ceil, floor
from datetime import datetime, timedelta
# sys.setrecursionlimit(10**7)

BLANK = " "

# inp = input
inp = lambda : sys.stdin.readline().rstrip()
mii = lambda x = BLANK : [*map(int,inp().split(x))]
mfi = lambda x = BLANK : [*map(float,inp().split(x))]
ii = lambda : int(inp())
fi = lambda : float(inp())
p = print


def solve():
  n, k, t = mii() # k는 기다리는 시간, t는 소포 전달 시간
  
  z = mii() # 사무실에서 수취인에게 도달하는데 걸리는 시간
  s = mii() # 수취인이 나타나는 시각
  
  crt = 0
  for i in range(n):
    crt += z[i]
    
    if crt >= s[i]:
      crt += t
    elif crt + k >= s[i]:
      crt = min(crt + k, s[i]) + t
    else:
      crt += k
  
  p(crt)
  
if __name__ == "__main__":
  tc = 1

  for t in range(1, tc+1):
    ret = solve()