結果
問題 | No.367 ナイトの転身 |
ユーザー | IWK623 |
提出日時 | 2016-07-07 15:13:30 |
言語 | C++11 (gcc 13.3.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 5,834 bytes |
コンパイル時間 | 1,394 ms |
コンパイル使用メモリ | 166,200 KB |
実行使用メモリ | 6,824 KB |
最終ジャッジ日時 | 2024-10-12 23:04:32 |
合計ジャッジ時間 | 4,238 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 2 ms
6,816 KB |
testcase_01 | AC | 1 ms
6,816 KB |
testcase_02 | AC | 1 ms
6,820 KB |
testcase_03 | AC | 1 ms
6,820 KB |
testcase_04 | AC | 2 ms
6,820 KB |
testcase_05 | AC | 1 ms
6,816 KB |
testcase_06 | AC | 1 ms
6,816 KB |
testcase_07 | AC | 2 ms
6,816 KB |
testcase_08 | AC | 2 ms
6,816 KB |
testcase_09 | AC | 2 ms
6,820 KB |
testcase_10 | WA | - |
testcase_11 | WA | - |
testcase_12 | WA | - |
testcase_13 | WA | - |
testcase_14 | WA | - |
testcase_15 | WA | - |
testcase_16 | WA | - |
testcase_17 | WA | - |
testcase_18 | WA | - |
testcase_19 | WA | - |
testcase_20 | AC | 180 ms
6,816 KB |
testcase_21 | WA | - |
testcase_22 | AC | 2 ms
6,816 KB |
testcase_23 | AC | 18 ms
6,816 KB |
testcase_24 | WA | - |
testcase_25 | WA | - |
testcase_26 | WA | - |
ソースコード
#include <bits/stdc++.h> using namespace std; class Node{ public: int x,y,cost; bool isWall,isGoal; int id; int pre; int type; public: Node(int nx,int ny,int ncost,bool ng,int nid,int npre,int ntype){ x = nx;//X y = ny;//Y cost = ncost;//このノードまでのコスト isGoal = ng;//ゴールかどうか id = nid;//自身のID pre = npre;//ひとつ前のノードのID type = ntype;//1 or 2 (1は♞2はミニビショップ) } }; class NodeList{ public: // iteratorをtypedefする typedef vector<Node>::iterator iterator; typedef vector<Node>::const_iterator const_iterator; // begin, end iterator begin(){ return datas.begin(); } const_iterator begin() const { return datas.begin(); } iterator end(){ return datas.end(); } const_iterator end() const { return datas.end(); } public: vector<Node> datas; // OpenListまたはCloseList. vector<Node>::iterator result; void push_data(Node n){ datas.push_back(n); } void remove(vector<Node>::iterator iterator){ datas.erase(iterator); } int getSize(){ return datas.size(); } vector<Node>::iterator getNode(int id){ vector<Node>::iterator iterator = datas.begin(); while (iterator != datas.end()){ if(id == (*iterator).id){ return iterator; } iterator++; }; return datas.end(); } Node getMinCost(){ vector<Node>::iterator iterator = datas.begin(); result = datas.begin(); int min = (*iterator).cost; while (iterator != datas.end()){ //cout << min << " <=> " << (*iterator).cost << endl; if(min > (*iterator).cost){ result = iterator; min = (*iterator).cost; } iterator++; } //remove(result); return *result; } vector<Node>::iterator find(int x,int y,int type){ vector<Node>::iterator iterator = datas.begin(); while (iterator != datas.end()){ if((*iterator).x == x and (*iterator).y == y and (*iterator).type == type){ return iterator; } iterator++; } return datas.end(); } bool isFind(vector<Node>::iterator it){ return datas.end() == it ? false : true; } }; int ChangeMode(int type,bool red){ if(!red){ return type; }else{ return type == 1 ? 2 : 1; } } int main(){ int n1,n2; cin >> n1 >> n2; //n1 = 250;n2 = 250; char map_char[n1][n2]; Node Start = Node(0,0,0,false,0,-1,1); Node Goal = Node(0,0,0,true,0,-1,0); /*for(int i = 0;i < n1;i++){ for(int j = 0;j < n2;j++){ map_char[i][j] = '.'; } }*/ for(int i = 0;i < n1;i++){ cin >> map_char[i]; } for(int i = 0;i < n1;i++){ for(int j = 0;j < n2;j++){ if(map_char[i][j] == 'S'){ Start.x = i; Start.y = j; }else if(map_char[i][j] == 'G'){ Goal.x = i; Goal.y = j; } } } Node now = Node(0,0,0,0,0,0,0); int pid = 0; Start.id = -1; Start.cost = sqrt(pow((Goal.x - Start.x),2) + pow((Goal.y - Start.y),2)); NodeList openMap; NodeList closeMap; openMap.push_data(Start); int move[2][8][2] = {{{1,2},{-1,2},{-1,-2},{1,-2},{2,1},{-2,1},{-2,-1},{2,-1}}, {{1,1},{1,-1},{-1,-1},{-1,1}}}; int cx,cy,min = -1; while(true){ if(openMap.getSize() <= 0 or pid >= 10000){ cout << min; return 0; } now = openMap.getMinCost();//計算中の中で一番コストの低いノードを取り出す。(同時に削除される。) openMap.remove(openMap.result); closeMap.push_data(now);//計算済みのほうへ移動。 //cout << now.id << ":" << now.pre << ":" << now.type << " (" << now.x + 1 << "," << now.y + 1<< ")" << now.cost << endl; if(now.x == Goal.x && now.y == Goal.y){ if(min > now.cost or min < 0){ min = now.cost; } } for(int i = 0;(now.type == 1 and i < 8) or (now.type == 2 and i < 4);i++){ cx = now.x + move[now.type - 1][i][0]; cy = now.y + move[now.type - 1][i][1]; if((cx < 0) or (cx > (n1 - 1)) or (cy < 0) or (cy > (n2 - 1)))continue; vector<Node>::iterator openFind = openMap.find(cx,cy,ChangeMode(now.type,(map_char[cx][cy] == 'R' ? true : false))); vector<Node>::iterator closeFind = closeMap.find(cx,cy,ChangeMode(now.type,(map_char[cx][cy] == 'R' ? true : false))); int fd = sqrt(pow((Goal.x - now.x),2) + pow((Goal.y - now.y),2)); if(openMap.isFind(openFind)){ Node ne = *openFind; if(ne.cost > now.cost+1){ ne.cost = (now.cost - fd) + (sqrt(pow((Goal.x - ne.x),2) + pow((Goal.y - ne.y),2))) + 1; //ne.cost = now.cost + 1; ne.pre = now.id; ne.type = ChangeMode(now.type,(map_char[cx][cy] == 'R' ? true : false)); } }else if(closeMap.isFind(closeFind)){ Node ne = *closeFind; if(ne.cost > now.cost+1){ closeMap.remove(closeFind); ne.cost = (now.cost - fd) + (sqrt(pow((Goal.x - ne.x),2) + pow((Goal.y - ne.y),2))) + 1; //ne.cost = now.cost + 1; ne.pre = now.id; ne.type = ChangeMode(now.type,(map_char[cx][cy] == 'R' ? true : false)); openMap.push_data(ne); } }else{ Node ne = Node(cx,cy,now.cost+1,false,pid,now.id, ChangeMode(now.type,(map_char[cx][cy] == 'R' ? true : false))); ne.cost = (now.cost - fd) + (sqrt(pow((Goal.x - ne.x),2) + pow((Goal.y - ne.y),2))) + 1; //ne.cost = now.cost + 1; pid++; openMap.push_data(ne); //cout << " > " << ne.id << ":" << ne.pre << ":" << ne.type << " (" << ne.x + 1 << "," << ne.y + 1<< ")" << ne.cost << endl; } } } /*int c = 0; cout << "to Path... "<< endl; while(true){ if(now.id < 0)break; cout << "<" << now.id << "," << now.pre << ">"; vector<Node>::iterator path = closeMap.getNode(now.pre); if(!closeMap.isFind(path)){ cout << endl << now.id << " (" << now.y+1 << "," << now.x+1 << ") " << now.pre << endl; vector<Node>::iterator path = openMap.getNode(now.pre); } now = *path; c++; } cout << endl; cout << c << endl;*/ }