답안 #151679

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
151679 2019-09-04T06:31:15 Z phillip Strah (COCI18_strah) C++14
66 / 110
1000 ms 67240 KB
#include <bits/stdc++.h>

using namespace std;
int n,m;
long double l[2009][2009];
char gr[2009][2009];
long long ans;
int main()
{
    cin>>n>>m;
    for(int i=0; i<n; i++)
    {
        cin>>gr[i];
    }
    if(n<m)
    {
        for(int i=0; i<n; i++)
        {
            for(int j=m-1; j>=0; j--)
            {
                if(gr[i][j]=='#')continue;
                l[i][j]=1+l[i][j+1];
            }
        }
        for(int i=0; i<n; i++)
        {
            for(int j=0; j<m; j++)
            {
                if(l[i][j]==0)continue;
                long double mn=l[i][j];
                for(int k=i; k<n; k++)
                {
                    mn=min(mn,l[k][j]);
                    if(mn==0)break;
                    long double r=(k-i+1);
                    //if(r==1)ans+=(mn*(mn+1))/2;
                    ans+=(((mn*r)+r)/2.0)*mn;
                }
                //       cout<<i<<" "<<j<<"-> "<<ans<<"\n";
            }
        }
    }
    else
    {
        for(int i=0; i<m; i++)
        {
            for(int j=n-1; j>=0; j--)
            {
                if(gr[j][i]=='#')continue;
                l[j][i]=1+l[j+1][i];
            }
        }
        for(int j=0; j<m; j++)
        {
            for(int i=0; i<n; i++)
            {
                if(l[i][j]==0)continue;
                long double mn=l[i][j];
                for(int k=j; k<m; k++)
                {
                    mn=min(mn,l[i][k]);
                    if(mn==0)break;
                    long double r=(k-j+1);
                    //if(r==1)ans+=(mn*(mn+1))/2;
                    ans+=(((mn*r)+r)/2.0)*mn;
                }
                //       cout<<i<<" "<<j<<"-> "<<ans<<"\n";
            }
        }
    }
    cout<<ans;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 400 KB Output is correct
2 Correct 2 ms 376 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 376 KB Output is correct
2 Correct 3 ms 376 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 16 ms 3704 KB Output is correct
2 Correct 25 ms 3704 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 15 ms 3576 KB Output is correct
2 Correct 25 ms 3600 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 120 ms 3672 KB Output is correct
2 Correct 25 ms 3668 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 145 ms 21840 KB Output is correct
2 Correct 762 ms 46912 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 337 ms 45024 KB Output is correct
2 Execution timed out 1067 ms 65216 KB Time limit exceeded
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1052 ms 28916 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 59 ms 15480 KB Output is correct
2 Execution timed out 1044 ms 57564 KB Time limit exceeded
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1054 ms 67240 KB Time limit exceeded
2 Halted 0 ms 0 KB -