結果

問題 No.232 めぐるはめぐる (2)
ユーザー motimoti
提出日時 2015-06-27 01:19:48
言語 C++11
(gcc 13.3.0)
結果
WA  
(最新)
AC  
(最初)
実行時間 -
コード長 1,259 bytes
コンパイル時間 622 ms
コンパイル使用メモリ 59,648 KB
実行使用メモリ 6,944 KB
最終ジャッジ日時 2024-07-07 19:50:05
合計ジャッジ時間 1,774 ms
ジャッジサーバーID
(参考情報)
judge4 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 21 WA * 1
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <iostream>
#include <algorithm>

using namespace std;

#define REP(i,a,b) for(int i=a;i<(int)b;i++)
#define rep(i,n) REP(i,0,n)

int main() {

  int T, A, B; cin >> T >> A >> B;
  int M = max(A,B);
  if(M>T) { cout << "NO\n"; return 0; }
  if(T==1&&A==0&&B==0) { cout << "NO\n"; return 0; }
  cout << "YES\n";
  if(A == B) {
    if(A==0) {
      if(T%2) { cout << ">^\nv\n<\n"; T-=3; }
      rep(i,T/2) cout << ">\n"; rep(i,T/2) cout << "<\n";
      return 0;
    }
    if(T==1) { cout << ">^\n"; return 0; }
    if(T==2) { cout << ">\n^\n"; return 0; }
    rep(i, A-1) cout << ">^\n";
    T-=A-1;
    if(T%2==0) { cout << ">\n^\n"; T-=2; }
    else { cout << ">^\n"; T--; }
    rep(i,T/2) cout << ">\n";
    rep(i,T/2) cout << "<\n";
    return 0;
  }
  int ur = min(A,B);
  rep(i, ur) cout << ">^\n";
  T -= ur;
  if(A < B) {
    rep(i,B-ur-1) cout << ">\n";
    T-=B-ur-1;
    if(T%2==0) { cout << "^\n>v\n"; T-=2; }
    else { cout << ">\n"; T--; }
    rep(i,T/2)cout << ">\n";
    rep(i,T/2)cout << "<\n";
  }
  else if(A > B) {
    swap(A,B);
    rep(i,B-ur-1) cout << "^\n";
    T-=B-ur-1;
    if(T%2==0) { cout << ">\n^<\n"; T-=2; }
    else { cout << "^\n"; T--; }
    rep(i,T/2)cout << "^\n";
    rep(i,T/2)cout << "v\n";
  }

  return 0;
}
0