結果
| 問題 |
No.232 めぐるはめぐる (2)
|
| コンテスト | |
| ユーザー |
lunnear
|
| 提出日時 | 2018-12-13 12:13:17 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 130 ms / 1,000 ms |
| コード長 | 1,385 bytes |
| コンパイル時間 | 679 ms |
| コンパイル使用メモリ | 56,060 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-09-14 12:45:40 |
| 合計ジャッジ時間 | 2,222 ms |
|
ジャッジサーバーID (参考情報) |
judge6 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 22 |
ソースコード
#include <iostream>
int sign(int val)
{
return (val>0) - (val<0);
}
int max(int a, int b)
{
return (a < b)? b:a;
}
int main()
{
int t, p[2];
int pos[2] = {0};
std::cin >> t >> p[0] >> p[1];
if((t < max(p[0], p[1])) || ((p[0] == 0) && (p[1] == 0) && (t == 1)))
{
std::cout << "NO" << std::endl;
return 0;
}
std::cout << "YES" << std::endl;
if(t == 1)
{
if(p[1])
std::cout << ">";
if(p[0])
std::cout << "^";
std::cout << std::endl;
return 0;
}
p[0]--;
p[1]--;
while((pos[0] != p[0]) || (pos[1] != p[1]))
{
char out[3] = {0};
int i = 0;
switch(sign(p[1] - pos[1]))
{
case 1: out[i] = '>'; pos[1]++; i++; break;
case -1: out[i] = '<'; pos[1]--; i++; break;
default:;
}
switch(sign(p[0] - pos[0]))
{
case 1: out[i] = '^'; pos[0]++; break;
case -1: out[i] = 'v'; pos[0]--; break;
default:;
}
t--;
std::cout << out << std::endl;
}
int i;
for(i = 0; t > 1; i++)
{
t--;
std::cout << (((i % 2) == 0)? ">":"<") << std::endl;
}
std::cout << (((i % 2) == 0)? ">^":"^") << std::endl;
return 0;
}
lunnear