Submission #162590
Source Code Expand
#include <cstdlib>
#include <cmath>
#include <climits>
#include <cfloat>
#include <map>
#include <utility>
#include <set>
#include <iostream>
#include <memory>
#include <string>
#include <vector>
#include <algorithm>
#include <functional>
#include <sstream>
#include <deque>
#include <complex>
#include <stack>
#include <queue>
#include <cstdio>
#include <cctype>
#include <cstring>
#include <ctime>
#include <iterator>
#include <bitset>
#include <numeric>
#include <list>
#include <iomanip>
#if __cplusplus >= 201103L
#include <array>
#include <tuple>
#include <initializer_list>
#include <unordered_set>
#include <unordered_map>
#include <forward_list>
#endif
using namespace std;
typedef long long LL;
typedef pair<int,int> pii;
typedef pair<LL,LL> pll;
typedef vector<int> vint;
typedef vector<vector<int> > vvint;
typedef vector<long long> vll, vLL;
typedef vector<vector<long long> > vvll, vvLL;
#define VV(T) vector<vector< T > >
template <class T>
void initvv(vector<vector<T> > &v, int a, int b, const T &t = T()){
v.assign(a, vector<T>(b, t));
}
template <class F, class T>
void convert(const F &f, T &t){
stringstream ss;
ss << f;
ss >> t;
}
#define REP(i,n) for(int i=0;i<int(n);++i)
#define ALL(v) (v).begin(),(v).end()
#define RALL(v) (v).rbegin(),(v).rend()
#define PB push_back
#define MOD 1000000009LL
#define EPS 1e-8
int main(){
int h, w, sy, sx, gy, gx;
cin >> h >> w >> sy >> sx >> gy >> gx;
--sy;
--sx;
--gy;
--gx;
vector<string> c(h);
for(int i = 0; i < h; ++i){
cin >> c[i];
}
if(!cin)throw 0;
int dd[] = {-1, 0, 1, 0, -1};
queue<int> q;
q.push(sy << 8 | sx);
q.push(-1);
int tm = 0;
while(1){
if(q.front() == -1){
q.pop();
q.push(-1);
++tm;
}
else{
int y = q.front() >> 8, x = q.front() & 255;
q.pop();
if(y == gy && x == gx){
break;
}
for(int i = 0; i < 4; ++i){
int ny = y + dd[i], nx = x + dd[i + 1];
if(c[ny][nx] == '.'){
c[ny][nx] = '_';
q.push(ny << 8 | nx);
}
}
}
}
cout << tm << endl;
}
Submission Info
Submission Time |
|
Task |
C - 幅優先探索 |
User |
climpet |
Language |
C++11 (GCC 4.8.1) |
Score |
100 |
Code Size |
2151 Byte |
Status |
AC |
Exec Time |
24 ms |
Memory |
932 KB |
Judge Result
Set Name |
Sample |
All |
Score / Max Score |
0 / 0 |
100 / 100 |
Status |
|
|
Set Name |
Test Cases |
Sample |
subtask0_sample01.txt, subtask0_sample02.txt, subtask0_sample03.txt |
All |
subtask0_sample01.txt, subtask0_sample02.txt, subtask0_sample03.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask1_13.txt, subtask1_14.txt, subtask1_15.txt, subtask1_16.txt, subtask1_17.txt, subtask1_18.txt, subtask1_19.txt, subtask1_20.txt, subtask1_21.txt, subtask1_22.txt |
Case Name |
Status |
Exec Time |
Memory |
subtask0_sample01.txt |
AC |
22 ms |
796 KB |
subtask0_sample02.txt |
AC |
21 ms |
924 KB |
subtask0_sample03.txt |
AC |
21 ms |
800 KB |
subtask1_01.txt |
AC |
21 ms |
924 KB |
subtask1_02.txt |
AC |
22 ms |
804 KB |
subtask1_03.txt |
AC |
21 ms |
928 KB |
subtask1_04.txt |
AC |
21 ms |
796 KB |
subtask1_05.txt |
AC |
22 ms |
760 KB |
subtask1_06.txt |
AC |
22 ms |
920 KB |
subtask1_07.txt |
AC |
24 ms |
796 KB |
subtask1_08.txt |
AC |
21 ms |
932 KB |
subtask1_09.txt |
AC |
21 ms |
804 KB |
subtask1_10.txt |
AC |
21 ms |
740 KB |
subtask1_11.txt |
AC |
24 ms |
800 KB |
subtask1_12.txt |
AC |
21 ms |
932 KB |
subtask1_13.txt |
AC |
22 ms |
920 KB |
subtask1_14.txt |
AC |
20 ms |
924 KB |
subtask1_15.txt |
AC |
22 ms |
924 KB |
subtask1_16.txt |
AC |
21 ms |
800 KB |
subtask1_17.txt |
AC |
21 ms |
808 KB |
subtask1_18.txt |
AC |
21 ms |
916 KB |
subtask1_19.txt |
AC |
21 ms |
800 KB |
subtask1_20.txt |
AC |
21 ms |
932 KB |
subtask1_21.txt |
AC |
20 ms |
928 KB |
subtask1_22.txt |
AC |
21 ms |
796 KB |