結果

問題 No.3527 Minimum Abs Sum
コンテスト
ユーザー K2
提出日時 2026-05-04 21:55:20
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
TLE  
(最新)
AC  
(最初)
実行時間 -
コード長 745 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 317 ms
コンパイル使用メモリ 85,296 KB
実行使用メモリ 171,636 KB
最終ジャッジ日時 2026-05-05 09:15:44
合計ジャッジ時間 30,300 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 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
    if A[i] < 0:
        A[i] = -A[i]
        B[i] = -B[i]
    a.append(A[i])
    b.append(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 = sum(A)
ra = 0
lb = sum(B)
rb = 0

y = -(la * X[idx[0]] - lb)
x = X[idx[0]]

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

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