結果
問題 | No.5020 Averaging |
ユーザー | judgelaw |
提出日時 | 2024-02-25 16:37:04 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 942 ms / 1,000 ms |
コード長 | 3,959 bytes |
コンパイル時間 | 324 ms |
コンパイル使用メモリ | 81,700 KB |
実行使用メモリ | 82,736 KB |
スコア | 24,260,276 |
最終ジャッジ日時 | 2024-02-25 16:38:54 |
合計ジャッジ時間 | 49,898 ms |
ジャッジサーバーID (参考情報) |
judge10 / judge15 |
純コード判定しない問題か言語 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 938 ms
81,008 KB |
testcase_01 | AC | 939 ms
82,152 KB |
testcase_02 | AC | 938 ms
80,848 KB |
testcase_03 | AC | 937 ms
81,972 KB |
testcase_04 | AC | 939 ms
80,972 KB |
testcase_05 | AC | 938 ms
81,860 KB |
testcase_06 | AC | 942 ms
81,392 KB |
testcase_07 | AC | 938 ms
82,432 KB |
testcase_08 | AC | 939 ms
80,856 KB |
testcase_09 | AC | 938 ms
80,744 KB |
testcase_10 | AC | 939 ms
81,508 KB |
testcase_11 | AC | 938 ms
82,192 KB |
testcase_12 | AC | 939 ms
81,136 KB |
testcase_13 | AC | 940 ms
81,316 KB |
testcase_14 | AC | 937 ms
81,184 KB |
testcase_15 | AC | 938 ms
81,004 KB |
testcase_16 | AC | 940 ms
81,312 KB |
testcase_17 | AC | 938 ms
82,736 KB |
testcase_18 | AC | 938 ms
81,364 KB |
testcase_19 | AC | 939 ms
82,292 KB |
testcase_20 | AC | 939 ms
80,796 KB |
testcase_21 | AC | 938 ms
81,720 KB |
testcase_22 | AC | 938 ms
80,592 KB |
testcase_23 | AC | 938 ms
80,504 KB |
testcase_24 | AC | 939 ms
81,272 KB |
testcase_25 | AC | 938 ms
81,376 KB |
testcase_26 | AC | 938 ms
81,772 KB |
testcase_27 | AC | 939 ms
81,160 KB |
testcase_28 | AC | 938 ms
81,296 KB |
testcase_29 | AC | 939 ms
80,860 KB |
testcase_30 | AC | 939 ms
81,092 KB |
testcase_31 | AC | 938 ms
81,876 KB |
testcase_32 | AC | 939 ms
82,232 KB |
testcase_33 | AC | 939 ms
80,348 KB |
testcase_34 | AC | 938 ms
82,392 KB |
testcase_35 | AC | 937 ms
80,824 KB |
testcase_36 | AC | 938 ms
81,440 KB |
testcase_37 | AC | 940 ms
80,644 KB |
testcase_38 | AC | 938 ms
82,300 KB |
testcase_39 | AC | 941 ms
80,984 KB |
testcase_40 | AC | 939 ms
80,204 KB |
testcase_41 | AC | 939 ms
81,184 KB |
testcase_42 | AC | 939 ms
80,976 KB |
testcase_43 | AC | 938 ms
81,336 KB |
testcase_44 | AC | 938 ms
81,884 KB |
testcase_45 | AC | 937 ms
81,752 KB |
testcase_46 | AC | 937 ms
81,132 KB |
testcase_47 | AC | 939 ms
81,352 KB |
testcase_48 | AC | 939 ms
80,692 KB |
testcase_49 | AC | 938 ms
80,208 KB |
ソースコード
from time import time st=time() import sys input = lambda: sys.stdin.readline().rstrip() from math import log10,exp from copy import copy,deepcopy from random import randint,random,choice MAX_OP=50 FIRST_PHASE=0.15 TIME_LIMIT=0.9 TARGET_NUM=5*10**17 INF=10**20 # カード1のスコアだけ見ればいいのか # 奇数回目の操作でカード1以外を操作する # 偶数回目でカード1を操作する # カード1のスコアを計算 def calc_front():return abs(tempAB[0][0]-TARGET_NUM) def calc_back():return abs(tempAB[0][1]-TARGET_NUM) def calc_Score(cnt): V1=calc_front() V2=calc_back() temp=max(V1,V2) if temp==0:return 2000050-cnt return int(2000000-100000*log10(temp+1)) # 二枚のカードの表裏の平均値を返す def calc_ave(u,v): retf=(tempAB[u][0]+tempAB[v][0])//2 retb=(tempAB[u][1]+tempAB[v][1])//2 return retf,retb def rewrite(u,v): tempf,tempb=calc_ave(u,v) tempAB[u][0]=tempf tempAB[v][0]=tempf tempAB[u][1]=tempb tempAB[v][1]=tempb def Judge(N,AB,X,UV): def WrongAnswer(i,s): print(str(i) + "th Wrong Answer (" + s + ")") exit(0) # Step 1. テストケースの入力を受け取る A = [0] * (N + 1) B = [0] * (N + 1) for i in range(1, N+1): A[i], B[i] = AB[i-1] # Step 2. あなたの出力を受け取る if X < 0 or X > 50: WrongAnswer("X is out of range") U = [0] * (X + 1) V = [0] * (X + 1) for i in range(1, X+1): U[i], V[i] = UV[i-1] if U[i] == V[i]: WrongAnswer(i,"U[i] and V[i] are same") elif U[i] < 1 or U[i] > N: WrongAnswer(i,"U[i] is out of range") elif V[i] < 1 or V[i] > N: WrongAnswer(i,"V[i] is out of range") # Step 3. シミュレーションを行う for i in range(1, X+1): avgA = (A[U[i]] + A[V[i]]) // 2 avgB = (B[U[i]] + B[V[i]]) // 2 A[U[i]] = avgA A[V[i]] = avgA B[U[i]] = avgB B[V[i]] = avgB # Step 4. 出力 ErrorA = abs(500000000000000000 - A[1]) ErrorB = abs(500000000000000000 - B[1]) Score = (int)(2000000.0 - 100000.0 * log10(1.0 * max(ErrorA, ErrorB) + 1.0)) if ErrorA == 0 and ErrorB == 0: Score = 2000050 - X print("Accepted!") print("Error of A[1] = " + str(ErrorA)) print("Error of B[1] = " + str(ErrorB)) print("Score = " + str(Score)) N=int(input()) AB=[list(map(int, input().split())) for _ in range(N)] NowScore=0 UV=[] ScoreMove=[] tarf=2*TARGET_NUM-AB[0][0] tarb=2*TARGET_NUM-AB[0][1] while time()-st<=TIME_LIMIT: tempAB=deepcopy(AB) tempUV=[] opcnt=MAX_OP-1 mmk=-1 mmv=INF # 奇数回目は1にマッチさせるものを選ぶ # 偶数回目で1とマッチさせる for cnt in range(opcnt): # 適当にu,vの平均を計算してaとマッチさせるような値が作れるか考える tu=randint(1,N-1) while tu==mmk:tu=randint(1,N-1) # 適当に選んだtuに対して最も適当なtvを選ぶ tv=-1 tempv=INF for v in range(1,N): if tu==v or v==mmk:continue tf,tb=calc_ave(tu,v) temp=abs(tf-tarf)+abs(tb-tarb) if temp<tempv: tv=v tempv=temp rewrite(tu,tv) tempUV.append((tu+1,tv+1)) if tempv<mmv: mmv=tempv mmk=tu # 1とさっき計算した最も良いものをマッチさせる rewrite(0,mmk) tempUV.append((1,mmk+1)) tempScore=calc_Score(MAX_OP) if tempScore>NowScore: NowScore=tempScore UV=deepcopy(tempUV) # else: # T=(time()-st)/TIME_LIMIT # if exp((tempScore-NowScore)/T)>random(): # NowScore=tempScore # UV=deepcopy(tempUV) ScoreMove.append(NowScore) L=len(UV) print(L) for u,v in UV:print(u,v)