結果

問題 No.3016 ハチマキおじさん
ユーザー 高橋ゆに
提出日時 2024-12-30 00:11:26
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 230 ms / 2,000 ms
コード長 550 bytes
コンパイル時間 2,032 ms
コンパイル使用メモリ 81,664 KB
実行使用メモリ 134,772 KB
最終ジャッジ日時 2025-01-25 22:08:13
合計ジャッジ時間 3,121 ms
ジャッジサーバーID
(参考情報)
judge3 / judge8
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 31
権限があれば一括ダウンロードができます

ソースコード

diff #

N = int(input())
A = list(map(int, input().split()))
B = list(map(int, input().split()))
A.sort()
B.sort()

pre_costs = [0 for _ in range(N)]
suf_costs = [0 for _ in range(N)]
for i in range(1, N):
    pre_costs[i] = abs(A[i - 1] - B[i - 1]) + pre_costs[i - 1]
    suf_costs[-(1 + i)] = abs(A[-i] - B[-i]) + suf_costs[-i]

min_cost = 10 ** 18
for i in range(N):
    min_cost = min(min_cost, pre_costs[i] + suf_costs[i])

ans = set()
for i in range(N):
    if pre_costs[i] + suf_costs[i] == min_cost:
        ans.add(A[i])

print(len(ans))
print(*ans)
0