結果

問題 No.1008 Bench Craftsman
ユーザー mkawa2mkawa2
提出日時 2020-03-07 12:09:07
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
WA  
実行時間 -
コード長 1,339 bytes
コンパイル時間 87 ms
コンパイル使用メモリ 12,800 KB
実行使用メモリ 49,848 KB
最終ジャッジ日時 2024-10-14 12:12:10
合計ジャッジ時間 4,295 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other WA * 2 TLE * 1 -- * 24
権限があれば一括ダウンロードができます

ソースコード

diff #

import sys

sys.setrecursionlimit(10 ** 6)
int1 = lambda x: int(x) - 1
p2D = lambda x: print(*x, sep="\n")
def II(): return int(sys.stdin.readline())
def MI(): return map(int, sys.stdin.readline().split())
def LI(): return list(map(int, sys.stdin.readline().split()))
def LLI(rows_number): return [LI() for _ in range(rows_number)]
def SI(): return sys.stdin.readline()[:-1]

def main():
    def ok(m):
        if m==0:
            s=sum(w for i,w in xw)
            for a in aa:
                if a<s:return False
            return True
        cs=[0]*n
        for i,w in xw:
            i-=1
            k=w//m
            if k==0:
                cs[i]+=w
                if i+1<n:cs[i+1]-=w*2
                if i+2<n:cs[i+2]+=w
            else:
                si=max(i-k,0)
                cs[si]+=w-m*(i-si)
                cs[si+1]+=m-cs[si]
                if i+1<n:cs[i+1]-=2*m
                if i+k<n:cs[i+k]+=m-(w-m*k)
                if i+k+1<n:cs[i+k+1]+=w-m*k
        for i in range(n-1):cs[i+1]+=cs[i]
        for i in range(n-1):cs[i+1]+=cs[i]
        for c,a in zip(cs,aa):
            if c>a:return False
        return True

    n,m=MI()
    aa=LI()
    xw=LLI(m)
    l=-1
    r=inf=10**9+5
    while l+1<r:
        m=(l+r)//2
        if ok(m):r=m
        else:l=m
    if r==inf:print(-1)
    else:print(r)

main()
0