結果
問題 | No.331 CodeRunnerでやれ |
ユーザー | koyumeishi |
提出日時 | 2015-12-25 00:31:59 |
言語 | C++11 (gcc 11.4.0) |
結果 |
RE
|
実行時間 | - |
コード長 | 3,915 bytes |
コンパイル時間 | 1,227 ms |
コンパイル使用メモリ | 113,064 KB |
実行使用メモリ | 25,604 KB |
平均クエリ数 | 816.47 |
最終ジャッジ日時 | 2024-07-16 08:25:12 |
合計ジャッジ時間 | 8,012 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | RE | - |
testcase_01 | AC | 148 ms
24,976 KB |
testcase_02 | RE | - |
testcase_03 | RE | - |
testcase_04 | RE | - |
testcase_05 | RE | - |
testcase_06 | RE | - |
testcase_07 | RE | - |
testcase_08 | RE | - |
testcase_09 | RE | - |
testcase_10 | RE | - |
testcase_11 | RE | - |
testcase_12 | RE | - |
testcase_13 | RE | - |
testcase_14 | RE | - |
testcase_15 | RE | - |
testcase_16 | RE | - |
ソースコード
#include <iostream> #include <vector> #include <cstdio> #include <sstream> #include <map> #include <string> #include <algorithm> #include <queue> #include <cmath> #include <functional> #include <set> #include <ctime> #include <stack> #include <random> using namespace std; template<class T> istream& operator >> (istream& is, vector<T>& vec){for(T& val: vec) is >> val; return is;} template<class T> istream& operator , (istream& is, T& val){ return is >> val;} template<class T> ostream& operator << (ostream& os, vector<T>& vec){for(int i=0; i<vec.size(); i++) os << vec[i] << (i==vec.size()-1?"\n":" ");return os;} int dx[] = {0,1,0,-1}; int dy[] = {1,0,-1,0}; int main(){ char buff[100]; int s = 0; // 0 ? // 1 visit // 2 wall // 3 space vector<vector<int>> field(50, vector<int>(50, 0)); int x = 25; int y = 25; int dir = 0; auto update = [&](){ string s(buff); if(s=="Merry Christmas!") return -1; if(s=="20151224") return -2; int d; sscanf(buff, "%d", &d); for(int k=1; k<=d; k++){ if(field[x + k*dx[dir]][y + k*dy[dir]] == 0) field[x + k*dx[dir]][y + k*dy[dir]] = 3; } field[x + (d+1)*dx[dir] ][ y + (d+1) * dy[dir] ] = 2; return d; }; auto check_foward = [&](){ return field[x + dx[dir] ][y + dy[dir]]; }; auto check_right = [&](){ return field[x + dx[(dir+1)%4]][y + dy[(dir+1)%4]]; }; auto check_left = [&](){ return field[x + dx[(dir+1)%4]][y + dy[(dir+1)%4]]; }; auto go_foward = [&](){ if(field[x + dx[dir]][y + dy[dir]] == 2) return; puts("F"); fflush(stdout); x += dx[dir]; y += dy[dir]; gets(buff); update(); }; auto go_backward = [&](){ if(field[x + dx[(dir+2)%2]][y + dy[(dir+2)%2]] == 2) return; puts("B"); fflush(stdout); x -= dx[dir]; y -= dy[dir]; gets(buff); update(); }; auto turn_right = [&](){ puts("R"); fflush(stdout); dir = (dir+1)%4; gets(buff); update(); }; auto turn_left = [&](){ puts("L"); fflush(stdout); dir = (dir+3)%4; gets(buff); update(); }; stack<pair<pair<int,int>,int>> st; auto move_ = [&](){ vector<vector<pair<int,int>>> last(50, vector<pair<int,int>>(50, {-1,-1})); queue<pair<int,int>> q; q.push(st.top().first); while(q.size()){ auto pos = q.front(); q.pop(); if(pos == st.top().first) break; //cerr << pos.first << " " << pos.second << " " << dir; int x_ = pos.first; int y_ = pos.second; for(int k__=0; k__<4; k__++){ int new_x = x_+ dx[k__]; int new_y = y_ + dy[k__]; if(field[new_x][new_y] == 0 || field[new_y][new_x] == 2) continue; //do something if(last[new_x][new_y] == last[0][0] ){ last[new_x][new_y] = {x_,y_}; q.push({x_,y_}); } } } while(pair<int,int>{x,y} != st.top().first){ auto p = last[x][y]; if(p == pair<int,int>{x+dx[(dir+1)%4], y+dy[(dir+1)%4]}){ turn_right(); go_foward(); }else if(p == pair<int,int>{x+dx[(dir+3)%4], y+dy[(dir+3)%4]}){ turn_left(); go_foward(); }else if(p == pair<int,int>{x+dx[(dir+2)%4], y+dy[(dir+2)%4]}){ go_backward(); }else{ go_foward(); } } while(pair<pair<int,int>,int>{{x,y},dir} != st.top()){ turn_right(); } }; gets(buff); while(true){ int d = update(); if(d==0) break; go_foward(); } while(true){ int d = update(); if(d==-1) return 0; if(d==-2){ go_foward(); continue; } if(field[x][y] != 1){ field[x][y] = 1; vector<pair<pair<int,int>,int>> hoge(5, {{-1,-1},-1}); for(int i=0; i<4; i++){ int z = check_foward(); if(z==0){ hoge[i] = {{x,y},dir}; //st.push({{x,y},dir}); //cerr << x << " " << y << " " << dir; } turn_right(); update(); } for(int i:{2,3,0,1}){ if(hoge[i] == hoge[4]) continue; st.push(hoge[i]); } } if(st.top() == pair<pair<int,int>,int>{{x,y}, dir}){ st.pop(); go_foward(); continue; }else{ move_(); } //cerr << field << endl; } return 0; }