結果
問題 | No.227 簡単ポーカー |
ユーザー |
|
提出日時 | 2015-06-19 22:27:04 |
言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,164 bytes |
コンパイル時間 | 1,468 ms |
コンパイル使用メモリ | 167,828 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-07 04:04:37 |
合計ジャッジ時間 | 2,326 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 14 |
ソースコード
#include <bits/stdc++.h> #define rep(i, n) for (int i = 0; i < (n); i++) #define rep2(i, a, b) for (int i = (a); i < (b); i++) #define rrep(i, n) for (int i = (n) - 1; i >= 0; i--) #define rrep2(i, a, b) for (int i = (a) - 1; i >= (b); i--) #define all(v) (v).begin(), (v).end() using namespace std; typedef long long ll; const ll inf = 1e9; const ll mod = 1e9 + 7; int a[5]; int num[14]; int solve() { map<int, int> m; rep (i, 5) m[a[i]]++; if (m.size() == 2) { if (m[a[0]] == 3 || m[a[0]] == 2) { return 0; } } for (auto p : m) { if (p.second == 3) return 1; } rep (i, 5) num[a[i]]++; int cnt = 0; rep (i, 14) { if (num[i] == 2) cnt++; } if (cnt == 2) return 2; else if (cnt == 1) return 3; return 4; } int main() { rep (i, 5) cin >> a[i]; sort(a, a + 5); switch (solve()) { case 0: cout << "FULL HOUSE" << endl; break; case 1: cout << "THREE CARD" << endl; break; case 2: cout << "TWO PAIR" << endl; break; case 3: cout << "ONE PAIR" << endl; break; default: cout << "NO HAND" << endl; break; } }