結果
| 問題 | 
                            No.1008 Bench Craftsman
                             | 
                    
| コンテスト | |
| ユーザー | 
                             mkawa2
                         | 
                    
| 提出日時 | 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 | 
ソースコード
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()
            
            
            
        
            
mkawa2