結果

問題 No.5003 物理好きクリッカー
ユーザー morumottomorumotto
提出日時 2018-12-10 01:11:40
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
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
権限があれば一括ダウンロードができます

ソースコード

diff #

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
0