#include using namespace std; #define rep(i,n) for (int i = 0; i < n; ++i) using ll = long long; using P = pair; vector G[10000]; vector color(10000,false); vector

ways={{1,0},{0,1},{-1,0},{0,-1}}; bool dfs(int v,int p=-1){ if(p==-1&&color[v])return false; if(color[v])return true; color[v]=true; bool res=false; for (auto &&i : G[v]){ if (i==p)continue; res|=dfs(i,v); } return res; } int main() { int M[102][102]; rep(i,102)M[i][0]=-1; rep(i,102)M[0][i]=-1; int W,H;cin>>W>>H; rep(i,102)M[H+1][i]=-1; rep(i,102)M[i][W+1]=-1; rep(i,H){ rep(j,W){ cin>>M[i+1][j+1]; } } rep(i,H){ rep(j,W){ for (auto &&way : ways){ int i_=i+way.first,j_=j+way.second; if(M[i+1][j+1]==M[i_+1][j_+1]){ G[i*W+j].push_back(i_*W+j_); } } } } rep(i,H*W){ if(dfs(i)){ cout<<"possible"<