結果
問題 |
No.1251 絶対に間違ってはいけない最小化問題
|
ユーザー |
|
提出日時 | 2025-01-03 16:39:49 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 737 ms / 2,000 ms |
コード長 | 359 bytes |
コンパイル時間 | 692 ms |
コンパイル使用メモリ | 82,172 KB |
実行使用メモリ | 146,300 KB |
最終ジャッジ日時 | 2025-01-03 16:40:21 |
合計ジャッジ時間 | 29,084 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 42 |
ソースコード
n=int(input()) A,B=[tuple(map(int,input().split())) for _ in range(2)] X=list(zip(A,B)) X.sort() A,B=zip(*X) X=[0] for x in B: X.append(X[-1]+x) kazuppa=0 for i in range(n): kazuppa+=B[i]*(A[i]-A[0]) ind=0 mn=kazuppa for i in range(1,n): kazuppa+=X[i]*(A[i]-A[i-1]) kazuppa-=(X[-1]-X[i])*(A[i]-A[i-1]) if kazuppa<mn: mn=kazuppa ind=i print(A[ind],mn)