結果

問題 No.3527 Minimum Abs Sum
コンテスト
ユーザー K2
提出日時 2026-05-04 21:36:47
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
WA  
実行時間 -
コード長 733 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 349 ms
コンパイル使用メモリ 85,400 KB
実行使用メモリ 171,864 KB
最終ジャッジ日時 2026-05-04 21:38:19
合計ジャッジ時間 42,803 ms
ジャッジサーバーID
(参考情報)
judge1_1 / judge2_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other WA * 28 TLE * 2
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

from fractions import Fraction

MOD = 10 ** 9 + 7

N = int(input())
A = list(map(int, input().split()))
B = list(map(int, input().split()))
a = []
b = []
for i in range(N):
    if A[i] == 0:
        continue
    a.append(A[i])
    b.append(B[i])
    if A[i] < 0:
        A[i] = -A[i]
        B[i] = -B[i]

A = a
B = b
N = len(A)

X = [Fraction(b, a) for a, b in zip(A, B)]

idx = list(range(N))
idx.sort(key=lambda i: X[i])

la = 0
ra = sum(A)
lb = 0
rb = sum(B)

y = -ra * X[0] + rb
x = X[0]

for i in idx:
    a = A[i]
    b = B[i]
    cx = X[i]
    la += a
    ra -= a
    lb += b
    rb -= b
    cy = (la - ra) * cx - (lb - rb)
    if cy < y:
        y = cy
        x = cx

print(x.numerator * pow(x.denominator, -1, MOD) % MOD)
0