#include using namespace std; /*{{{*/ //template #define rep(i,n) for(int i=0;i::max()/2; constexpr long long LINF = numeric_limits::max()/3; #define mp make_pair #define pb push_back #define eb emplace_back #define fi first #define se second #define all(v) (v).begin(),(v).end() #define sz(x) (int)(x).size() #define debug(x) cerr<<#x<<":"< ostream& operator<<(ostream& os,const vector& vec){ os << "["; for(const auto& v : vec){ os << v << ","; } os << "]"; return os; } template ostream& operator<<(ostream& os,const pair& p){ os << "(" << p.first << ","<< p.second <<")"; return os; } template ostream& operator<<(ostream& os,const set& st){ os<<"{"; for(T v:st) os< inline void chmax(T &x,U y){ if(y>x) x = y; } template inline void chmin(T &x,U y){ if(y pii; typedef vector vi; typedef vector vvi; ll gcd(ll a,ll b){ if(b==0) return a; else return gcd(b,a%b); } //constexpr double eps = 1e-14; constexpr double eps = 1e-10; constexpr ll mod = 1e9+7; const int dx[]={1,0,-1,0} ,dy[] = {0,1,0,-1}; /*}}}*/ int h,w; vector tab; int main(){ cin>>h>>w; tab.resize(h); rep(i,h) cin>>tab[i]; int cnt=0; rep(i,h) rep(j,w) if(tab[i][j]=='#') cnt++; if(cnt==0 or cnt%2==1){ cout << "NO" << endl; return 0; } for(int dx=-h+1;dx=h or ny>=w or s[nx][ny]!='#'){ //cerr << dx << " " << dy << " " << x << " " << y << endl; f=false; return; } s[x][y] = 'R'; s[nx][ny] = 'B'; } } }(); if(f){ //cerr << dx << " "<< dy << endl; cout << "YES" << endl; return 0; } } cout << "NO" << endl; }