結果
問題 | No.5020 Averaging |
ユーザー | judgelaw |
提出日時 | 2024-02-25 15:57:10 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 940 ms / 1,000 ms |
コード長 | 3,960 bytes |
コンパイル時間 | 258 ms |
コンパイル使用メモリ | 81,700 KB |
実行使用メモリ | 84,940 KB |
スコア | 29,622,304 |
最終ジャッジ日時 | 2024-02-25 15:58:01 |
合計ジャッジ時間 | 50,683 ms |
ジャッジサーバーID (参考情報) |
judge12 / judge11 |
純コード判定しない問題か言語 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 939 ms
83,580 KB |
testcase_01 | AC | 939 ms
83,464 KB |
testcase_02 | AC | 940 ms
83,612 KB |
testcase_03 | AC | 940 ms
83,900 KB |
testcase_04 | AC | 938 ms
83,548 KB |
testcase_05 | AC | 939 ms
84,940 KB |
testcase_06 | AC | 940 ms
83,728 KB |
testcase_07 | AC | 938 ms
83,868 KB |
testcase_08 | AC | 939 ms
83,332 KB |
testcase_09 | AC | 938 ms
83,336 KB |
testcase_10 | AC | 940 ms
83,072 KB |
testcase_11 | AC | 938 ms
84,352 KB |
testcase_12 | AC | 938 ms
82,752 KB |
testcase_13 | AC | 939 ms
82,552 KB |
testcase_14 | AC | 939 ms
83,592 KB |
testcase_15 | AC | 940 ms
84,184 KB |
testcase_16 | AC | 939 ms
84,348 KB |
testcase_17 | AC | 938 ms
83,440 KB |
testcase_18 | AC | 938 ms
83,056 KB |
testcase_19 | AC | 939 ms
83,708 KB |
testcase_20 | AC | 939 ms
83,372 KB |
testcase_21 | AC | 938 ms
83,712 KB |
testcase_22 | AC | 939 ms
83,804 KB |
testcase_23 | AC | 938 ms
84,260 KB |
testcase_24 | AC | 938 ms
84,724 KB |
testcase_25 | AC | 939 ms
83,292 KB |
testcase_26 | AC | 940 ms
83,580 KB |
testcase_27 | AC | 940 ms
83,560 KB |
testcase_28 | AC | 940 ms
83,096 KB |
testcase_29 | AC | 939 ms
83,292 KB |
testcase_30 | AC | 939 ms
83,768 KB |
testcase_31 | AC | 938 ms
84,056 KB |
testcase_32 | AC | 939 ms
83,584 KB |
testcase_33 | AC | 938 ms
84,160 KB |
testcase_34 | AC | 938 ms
83,428 KB |
testcase_35 | AC | 939 ms
84,232 KB |
testcase_36 | AC | 939 ms
82,792 KB |
testcase_37 | AC | 939 ms
84,152 KB |
testcase_38 | AC | 937 ms
83,716 KB |
testcase_39 | AC | 939 ms
82,796 KB |
testcase_40 | AC | 939 ms
83,564 KB |
testcase_41 | AC | 939 ms
83,588 KB |
testcase_42 | AC | 940 ms
83,900 KB |
testcase_43 | AC | 939 ms
84,068 KB |
testcase_44 | AC | 938 ms
84,012 KB |
testcase_45 | AC | 938 ms
83,036 KB |
testcase_46 | AC | 940 ms
82,812 KB |
testcase_47 | AC | 939 ms
82,712 KB |
testcase_48 | AC | 939 ms
83,948 KB |
testcase_49 | AC | 939 ms
83,160 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 # カード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(str): print("Wrong Answer (" + str + ")") sys.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("U[i] and V[i] are same") elif U[i] < 1 or U[i] > N: WrongAnswer("U[i] is out of range") elif V[i] < 1 or V[i] > N: WrongAnswer("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=[] while time()-st<=TIME_LIMIT: tempAB=deepcopy(AB) tempUV=[] preop=-1 opcnt=randint(0,MAX_OP) # 奇数回目は1にマッチさせるものを選ぶ # 偶数回目で1とマッチさせる for cnt in range(1,opcnt+1): if cnt&1: tarf=2*TARGET_NUM-tempAB[0][0] tarb=2*TARGET_NUM-tempAB[0][1] pretemp=10**20 u,v=-1,-1 # 適当にu,vの平均を計算してaとマッチさせられるか考える for _ in range(20): tu=randint(1,N-1) tv=randint(1,N-1) while tu==tv:tv=randint(1,N-1) tf,tb=calc_ave(tu,tv) temp=abs(tf-tarf)+abs(tb-tarb) if temp<pretemp: pretemp=temp u=tu v=tv rewrite(u,v) tempUV.append((u+1,v+1)) preop=u else: # 1とさっき計算したものをマッチさせる rewrite(0,preop) tempUV.append((1,preop+1)) tempScore=calc_Score(opcnt) 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)