//#if 0
#include <map>
#include <stack>
#include <queue>
#include <vector>
#include <math.h>
#include <string>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <algorithm>
#include <time.h>
#include <set>
#include <list>
#include <iostream>
using namespace std;
#define ll long long
#define ull unsigned long long
#define cls(x) memset(x,0,sizeof(x))
#define clslow(x) memset(x,-1,sizeof(x))
#define INF 0x3f3f3f3f
const int maxn=2e4+50;
int r,c;
char maz[505][505];
int cal()
{
int ans=0,flag=0;
for(int i=0;i<r;i++){
for(int j=0;j<c;j++){
if(i==0 || i==r-1 || j==0 || j==c-1){
if(i==0 && j==0)continue;
if(i==0 && j==c-1)continue;
if(i==r-1 && j==0)continue;
if(i==r-1 && j==c-1)continue;
if(maz[i][j]=='#')flag=1;
}
else{
if(maz[i][j]=='.')ans++;
}
}
}
if(flag==0)ans++;
return ans;
}
int main()
{
// freopen("in1.txt","r",stdin);
scanf("%d%d",&r,&c);
for(int i=0;i<r;i++){
scanf("%s",maz[i]);
}
int ans=0;
if(r==1){
for(int i=1;i<c-1;i++){
if(maz[0][i]=='.')ans++;
}
}
else if(c==1){
for(int i=1;i<r-1;i++){
if(maz[i][0]=='.')ans++;
}
}
else if(r==2){
for(int i=1;i<c-1;i++){
if(maz[0][i]=='.' && maz[1][i]=='.')ans++;
}
}
else if(c==2){
for(int i=1;i<r-1;i++){
if(maz[i][0]=='.' && maz[i][1]=='.')ans++;
}
}
else{
ans=cal();
}
cout<<ans<<endl;
return 0;
}
//#endif
2018 ICPC Asia Jakarta Regional Contest Gym - 102001D. Icy Land
最新推荐文章于 2021-08-26 16:10:52 发布