結果
問題 | No.5003 物理好きクリッカー |
ユーザー | morumotto |
提出日時 | 2018-12-10 01:11:40 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 100 ms / 10,000 ms |
コード長 | 2,528 bytes |
コンパイル時間 | 60 ms |
実行使用メモリ | 22,824 KB |
スコア | 17,456,280,027 |
平均クエリ数 | 10000.00 |
最終ジャッジ日時 | 2021-07-19 09:17:49 |
合計ジャッジ時間 | 5,669 ms |
ジャッジサーバーID (参考情報) |
judge14 / judge15 |
純コード判定しない問題か言語 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 97 ms
22,460 KB |
testcase_01 | AC | 100 ms
22,456 KB |
testcase_02 | AC | 95 ms
22,608 KB |
testcase_03 | AC | 94 ms
22,640 KB |
testcase_04 | AC | 94 ms
22,304 KB |
testcase_05 | AC | 100 ms
22,704 KB |
testcase_06 | AC | 94 ms
22,444 KB |
testcase_07 | AC | 97 ms
22,732 KB |
testcase_08 | AC | 98 ms
22,260 KB |
testcase_09 | AC | 98 ms
22,636 KB |
testcase_10 | AC | 100 ms
22,544 KB |
testcase_11 | AC | 98 ms
22,680 KB |
testcase_12 | AC | 97 ms
22,676 KB |
testcase_13 | AC | 97 ms
22,708 KB |
testcase_14 | AC | 97 ms
22,476 KB |
testcase_15 | AC | 95 ms
22,716 KB |
testcase_16 | AC | 98 ms
22,712 KB |
testcase_17 | AC | 96 ms
22,596 KB |
testcase_18 | AC | 96 ms
22,576 KB |
testcase_19 | AC | 96 ms
22,464 KB |
testcase_20 | AC | 99 ms
22,368 KB |
testcase_21 | AC | 97 ms
22,824 KB |
testcase_22 | AC | 97 ms
22,456 KB |
testcase_23 | AC | 98 ms
22,408 KB |
testcase_24 | AC | 96 ms
22,464 KB |
testcase_25 | AC | 96 ms
22,356 KB |
testcase_26 | AC | 96 ms
22,692 KB |
testcase_27 | AC | 96 ms
22,644 KB |
testcase_28 | AC | 99 ms
22,436 KB |
testcase_29 | AC | 95 ms
22,348 KB |
testcase_30 | AC | 99 ms
22,776 KB |
testcase_31 | AC | 98 ms
22,300 KB |
ソースコード
import math n = int(input()) s = input() fac_power = {"enhclick":1, "hand":1, "lily":10, "factory":120, "casino":2000, "grimoire":25000} buy_count = {"enhclick":0, "hand":0, "lily":0, "factory":0, "casino":0, "grimoire":0} buy_price = {"buy hand":150, "buy lily":2000, "buy factory":30000, "buy casino":600000, "buy grimoire":10000000} rei_price = {"enhclick":15, "reinforce hand":1500, "reinforce lily":20000, "reinforce factory":300000, "reinforce casino":6000000, "reinforce grimoire":100000000} fac_names = {"hand", "lily", "factory", "casino", "grimoire"} CLICK_RATIO = 0.5 turn = 0 cookie_count = 0 fever = 0 sale = False while turn < n: #------------- player_action ------------- act = None price = 0 score = 0 #buy for k, v in buy_price.items(): if sale: v *= 0.9 if cookie_count >= v: ev = fac_power[k.split()[-1]] * (n - turn) - v if score < ev: act, price, score = k, v, ev #reinforce for k, v in rei_price.items(): if sale: v *= 0.9 if cookie_count >= v: ev = fac_power[k.split()[-1]] * buy_count[k.split()[-1]] * (n - turn) - v if k == "enhclick": ev *= CLICK_RATIO if score < ev: act, price, score = k, v, ev # for k, v in rei_price.items(): # if k == "enhclick":continue # ev = v * 0.25 - fac_power[k.split()[-1]] * (n - turn) # if score < ev: # act, price, score = "sell " + k.split()[-1], - math.ceil(v * 0.25), if act == None: print("click") cookie_count += fac_power["enhclick"] else: if act in buy_price: print(act) buy_price[act] = math.ceil(buy_price[act] * 1.2) buy_count[act.split()[-1]] += 1 cookie_count -= math.ceil(price) elif act in rei_price: print(act) rei_price[act] *= 10 fac_power[act.split()[-1]] *= 2 cookie_count -= math.ceil(price) #------------- facility_action ----------- add = sum([fac_power[k] * buy_count[k] for k in fac_names]) if fever: add *= 7 fever -= 1 cookie_count += add #------------- special_action ------------ special_act = s[turn] if s == "B": cookie_count += math.ceil(cookie_count / 100) elif s == "F": fever = 20 elif s == "S": sale = True #------------- turn++ ------------------ turn += 1