結果

問題 No.227 簡単ポーカー
ユーザー asatakeasatake
提出日時 2018-08-13 09:26:12
言語 Elixir
(1.16.2)
結果
WA  
実行時間 -
コード長 600 bytes
コンパイル時間 1,164 ms
コンパイル使用メモリ 63,148 KB
実行使用メモリ 55,176 KB
最終ジャッジ日時 2024-06-09 22:11:04
合計ジャッジ時間 10,146 ms
ジャッジサーバーID
(参考情報)
judge1 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 AC 550 ms
54,252 KB
testcase_02 AC 559 ms
54,132 KB
testcase_03 AC 757 ms
53,616 KB
testcase_04 AC 579 ms
54,044 KB
testcase_05 AC 560 ms
53,980 KB
testcase_06 WA -
testcase_07 AC 552 ms
53,868 KB
testcase_08 WA -
testcase_09 AC 557 ms
54,460 KB
testcase_10 AC 552 ms
54,212 KB
testcase_11 AC 555 ms
54,128 KB
testcase_12 AC 547 ms
54,876 KB
testcase_13 AC 548 ms
54,104 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
    warning: Map.size/1 is deprecated. Use Kernel.map_size/1 instead
    │
 21 │       Map.size(m) === 2 -> "FULL HOUSE"
    │           ~
    │
    └─ Main.exs:21:11: Main.judge/1
    └─ Main.exs:22:11: Main.judge/1
    └─ Main.exs:23:11: Main.judge/1

ソースコード

diff #

defmodule Main do
  def main() do
    a = IO.gets("") |> String.trim |> String.split
    IO.puts judge(count(%{}, a))
  end

  def count(m, []) do
    m
  end

  def count(m, [h | t]) do
    new_m = case Map.has_key?(m, h) do
      false -> Map.put_new(m, h, 1)
      true -> Map.update!(m, h, fn x -> x + 1 end)
    end
    count(new_m, t)
  end

  def judge(m) do
    cond do
      Map.size(m) === 2 -> "FULL HOUSE"
      Map.size(m) === 4 -> "ONE PAIR"
      Map.size(m) === 5 -> "NO HAND"
      Map.values(m) |> Enum.sort === [1, 1, 3] -> "THREE CARD"
      true -> "TWO PAIR"
    end
  end

end
0