ferinの競プロ帳

競プロについてのメモ

CODE FESTIVAL 2017 Final A - AKIBA

問題ページ
A - AKIBA

考えたこと

  1. Aを飛ばしてKIHBRになればYESという方針で実装を始める
  2. 300だしどうせ通るだろーと軽い気持ちでいたら落ちる
  3. 実装バグらせたのを見つけて直して出すと落ちる
  4. "KIHBRAA"、"KAIBHR"あたりのケースを見逃しまくっていた

どうせ300だし一瞬で解けるだろうと思って解いたらバグらせまくり無駄に複雑な実装にして20分かけて反省。埋め込みか2^5全列挙で書くべきだった。

//#define __USE_MINGW_ANSI_STDIO 0
#include <bits/stdc++.h>

using namespace std;
typedef long long ll;
#define int ll
typedef vector<int> VI;
typedef vector<VI> VVI;
typedef vector<ll> VL;
typedef vector<VL> VVL;
typedef pair<int, int> PII;

#define FOR(i, a, n) for (ll i = (ll)a; i < (ll)n; ++i)
#define REP(i, n) FOR(i, 0, n)
#define ALL(x) x.begin(), x.end()
#define IN(a, b, x) (a<=x&&x<b)
#define MP make_pair
#define PB push_back
#ifdef int
const ll INF = (1LL<<60);
#else
const int INF = (1LL<<30);
#endif
const double PI = 3.14159265359;
const double EPS = 1e-12;
const int MOD = 1000000007;

template <typename T> T &chmin(T &a, const T &b) { return a = min(a, b); }
template <typename T> T &chmax(T &a, const T &b) { return a = max(a, b); }

int dx[] = {0, 1, 0, -1}, dy[] = {1, 0, -1, 0};

signed main(void)
{
  string s;
  cin >> s;
  string t = "KIHBR$$$$";
  int cnt = 0, tmp = 0;
  if(s.size() >= 10) {
    cout << "NO" << endl;
    return 0;
  }
  REP(i, s.size()) {
    if(s[i] == 'A') i++, tmp++;
    else tmp = 0;
    if(tmp > 1 || (cnt == 1 && tmp > 0) || (cnt == 2 && tmp > 0)) {
      cout << "NO" << endl;
      return 0;
    }
    if(s[i] != 'A') tmp = 0;
    if(i<s.size() && s[i] != t[cnt++]) {
      cout << "NO" << endl;
      return 0;
    }
  }
  if(cnt != 5) cout << "NO" << endl;
  else cout << "YES" << endl;

  return 0;
}