#ifdef __GNUC__ #pragma GCC optimize ("O3") #pragma GCC target ("avx") #endif #define _USE_MATH_DEFINES #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include //assert(); #include ///////// #define REP(i, x, n) for(int i = x; i < n; i++) #define rep(i,n) REP(i,0,n) ///////// typedef long long LL; typedef long double LD; typedef unsigned long long ULL; #define PII pair ///////// using namespace::std; // 最大公約数 template inline T gcd(T a, T b){return b == 0 ? a : gcd(b, a % b);} // 最小公倍数 template inline T lcm(T a, T b){return a * b / gcd(a, b);} //////////////////////////////// //(x-r,y-r)-(x+r,y+r) //(2*r+1)**2 bool kyori(vector>& wa,int h,int w,int x,int y,int r){ if( x-r < 0 || y-r < 0 )return false; if( w <= x+r || h <= y+r )return false; int sum=0; sum = wa[y+r][x+r]; int X,Y; X = x-r-1; Y = y-r-1; if( X >=0 && Y >= 0 ){ sum += wa[Y][X]; } if( X >= 0 ){sum -= wa[y+r][X];} if( Y >= 0 ){sum -= wa[Y][x+r];} return sum == (2*r+1)*(2*r+1); } inline void solve(){ int H,W; scanf("%d%d",&H,&W); char str[3001]; //累積和 vector> wa(H,vector(W,0)); for(int i=0;i