#include using namespace std; typedef long long ll; int dy[]={0,1,0,-1}; int dx[]={1,0,-1,0}; int h,w; void dfs(int y,int x,string s[],vector>& v) { v[y][x]=1; for (int i=0;i<4;i++) { int ny=y+dy[i]; int nx=x+dx[i]; if (ny<0||h<=ny||nx<0||w<=nx) continue; if (abs(s[y][x]-s[ny][nx])<=1) dfs(ny,nx,s,v); int ny2=ny+dy[i]; int nx2=nx+dx[i]; if (ny2<0||h<=ny2||nx2<0||w<=nx2) continue; if (s[y][x]==s[ny2][nx2]&&s[y][x]>s[ny][nx]) dfs(ny2,nx2,s,v); } } int main() { int sy,sx,gy,gx; cin>>h>>w>>sy>>sx>>gy>>gx; sy--,sx--,gy--,gx--; string s[h]; for (int i=0;i>s[i]; vector> v(h,vector(w,0)); dfs(sy,sx,s,v); if (v[gy][gx]) puts("YES"); else puts("NO"); return 0; }