結果
| 問題 |
No.5020 Averaging
|
| コンテスト | |
| ユーザー |
titia
|
| 提出日時 | 2024-02-25 16:19:10 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,329 bytes |
| コンパイル時間 | 272 ms |
| コンパイル使用メモリ | 81,700 KB |
| 実行使用メモリ | 83,696 KB |
| スコア | 0 |
| 最終ジャッジ日時 | 2024-02-25 16:20:01 |
| 合計ジャッジ時間 | 50,233 ms |
|
ジャッジサーバーID (参考情報) |
judge10 / judge14 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | WA * 50 |
ソースコード
import sys
input = sys.stdin.readline
from random import randint
from time import time
time0=time()
N=int(input())
A=[list(map(int,input().split())) for i in range(N)]
A_INI=[]
for a,b in A:
A_INI.append([a,b])
LANS=[]
score=10**18
while time()-time0<0.9:
ANS=[]
A=[]
for a,b in A_INI:
A.append([a,b])
for i in range(49):
while True:
x,y=randint(0,N-1),randint(0,N-1)
if x==y:
continue
else:
break
c=(A[x][0]+A[y][0])//2
d=(A[x][1]+A[y][1])//2
A[x][0]=A[y][0]=c
A[x][1]=A[y][1]=d
ANS.append(x)
ANS.append(y)
if x!=0:
c0=(A[0][0]+A[x][0])//2
d0=(A[0][1]+A[x][1])//2
if max(abs(5*(10**17)-c0),abs(5*(10**17)-d0))<score:
score=max(abs(5*(10**17)-c0),abs(5*(10**17)-d0))
LANS=ANS[:]+[0]+[x]
if y!=0:
c0=(A[0][0]+A[y][0])//2
d0=(A[0][1]+A[y][1])//2
if max(abs(5*(10**17)-c0),abs(5*(10**17)-d0))<score:
score=max(abs(5*(10**17)-c0),abs(5*(10**17)-d0))
LANS=ANS[:]+[0]+[y]
print(len(LANS)//2)
for i in range(0,len(LANS),2):
print(LANS[i],LANS[i+1])
titia