結果

問題 No.3527 Minimum Abs Sum
コンテスト
ユーザー tassei903
提出日時 2026-05-04 21:45:01
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
AC  
実行時間 379 ms / 2,000 ms
コード長 966 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 224 ms
コンパイル使用メモリ 85,152 KB
実行使用メモリ 143,004 KB
最終ジャッジ日時 2026-05-04 21:45:16
合計ジャッジ時間 10,325 ms
ジャッジサーバーID
(参考情報)
judge1_1 / judge3_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 30
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import sys
input = lambda :sys.stdin.readline()[:-1]
ni = lambda :int(input())
na = lambda :list(map(int,input().split()))
yes = lambda :print("yes");Yes = lambda :print("Yes");YES = lambda : print("YES")
no = lambda :print("no");No = lambda :print("No");NO = lambda : print("NO")
#######################################################################

"""
|a||x - b / a|

-1 -1 1 1 1 1
0 2 4 6

-1 -1 1 1
0 2 4
rui[i] >= s / 2

"""

BIG = 10 ** 20
def f(a, b):
    if b < 0:
        a = -a
        b = -b
    return (2 * a * BIG + b) // (2 * b)


n = ni()
a = na()
b = na()
idx = [i for i in range(n) if a[i] != 0]
a = [a[i] for i in idx]
b = [b[i] for i in idx]
n = len(a)

s = sorted(range(n), key = lambda i: f(b[i], a[i]))

rui = [0] * (n + 1)
for i in range(n):
    rui[i+1] = rui[i] + abs(a[s[i]]) * 2

from bisect import bisect_left
t = rui[-1] // 2
i = s[bisect_left(rui, t) - 1]
mod = 10 ** 9 + 7
# print(rui, i)

print(b[i] * pow(a[i], mod-2, mod) % mod)
0