結果

問題 No.1534 おなかがいたい
ユーザー norioc
提出日時 2024-08-13 21:37:13
言語 Elixir
(1.18.1)
結果
AC  
実行時間 843 ms / 2,000 ms
コード長 576 bytes
コンパイル時間 1,972 ms
コンパイル使用メモリ 62,032 KB
実行使用メモリ 73,212 KB
最終ジャッジ日時 2024-08-13 21:37:34
合計ジャッジ時間 20,073 ms
ジャッジサーバーID
(参考情報)
judge1 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 19
権限があれば一括ダウンロードができます

ソースコード

diff #

defmodule Main do
  def input, do: IO.read(:line) |> String.trim
  def ii, do: input() |> String.to_integer
  def li, do: input() |> String.split |> Enum.map(&String.to_integer/1)
  def yn(b), do: IO.puts(if b, do: "Yes", else: "No")

  def main do
    s = input() |> String.to_charlist
    f(s, 0, -1)
    |> IO.puts
  end

  def f(xs, k, m) do
    case xs do
      [?p, ?a, ?i, ?n | ys] -> f(ys, 0, max(pon(k), m))
      [?p, ?o, ?n | ys] -> f(ys, k+1, m)
      [_ | ys] -> f(ys, k, m)
      [] -> m
    end
  end

  def pon(k) do
    if k >= 2, do: k-1, else: -1
  end
end
0