/ SeriousOJ /

Record Detail

Accepted


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 584.0 KiB
#2 Accepted 9ms 540.0 KiB
#3 Accepted 11ms 772.0 KiB
#4 Accepted 12ms 540.0 KiB
#5 Accepted 10ms 540.0 KiB
#6 Accepted 5ms 540.0 KiB
#7 Accepted 13ms 540.0 KiB
#8 Accepted 31ms 540.0 KiB
#9 Accepted 31ms 652.0 KiB
#10 Accepted 32ms 796.0 KiB
#11 Accepted 14ms 584.0 KiB
#12 Accepted 14ms 1.277 MiB
#13 Accepted 18ms 1.504 MiB
#14 Accepted 15ms 1.297 MiB
#15 Accepted 17ms 1.496 MiB
#16 Accepted 15ms 1.496 MiB
#17 Accepted 15ms 1.277 MiB
#18 Accepted 506ms 1.574 MiB
#19 Accepted 22ms 1.547 MiB
#20 Accepted 438ms 1.496 MiB
#21 Accepted 51ms 4.527 MiB
#22 Accepted 135ms 4.363 MiB
#23 Accepted 141ms 4.527 MiB
#24 Accepted 141ms 4.367 MiB
#25 Accepted 123ms 4.367 MiB
#26 Accepted 633ms 4.574 MiB
#27 Accepted 149ms 4.371 MiB
#28 Accepted 119ms 4.527 MiB
#29 Accepted 1109ms 4.586 MiB
#30 Accepted 1491ms 4.363 MiB

Code

#include <bits/stdc++.h>
using namespace std;
#define optimize() ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define all(v) (v).begin(),(v).end()
#define rall(v) (v).rbegin(),(v).rend()
#define ll long long
#define endl '\n'
#define gap " "
#define bug(a) cerr<<#a<<":"<<a<<endl;
#define gcd __gcd(a,b)
#define lcm (a*b)/(__gcd(a,b))
#define pb push_back
#define yes cout<<"YES"<<endl;
#define no cout<<"NO"<<endl;
const double pi=acos(-1);
const ll mod=1000000007;
#define tc ll t;cin>>t;while(t--)
int main()
{
    optimize()
    tc
    {
        ll n,m;
        cin>>n>>m;
        char arr[n][m];
        ll i,j,k,l,n1,n2;
        ll maxi=0;
        ll cnt=0;
        for(i=0;i<n;i++)
        {
            for(j=0;j<m;j++)
            {
                cin>>arr[i][j];
                if(arr[i][j]=='+')
                {
                    cnt++;
                }
            }
        }
        if(cnt==(n*m))
        {
            ll x=n,y=m;
            ll mini=min(n,m);
            if(mini%2==0)
            {
                mini/=2;
                mini--;
                mini*=4;
                mini++;
                cout << mini << endl;
            }
            else
            {
                mini/=2;
                //mini--;
                mini*=4;
                mini++;
                cout << mini << endl;
            }
        }
        else {
        for(i=0;i<n;i++)
        {
            
            for(j=0;j<m;j++)
            {
                if(arr[i][j]=='+')
                {
                
                    ll c1=0;
                    for(k=i+1, l=i-1, n1=j+1, n2=j-1;k<n && l>=0 && n1<m && n2>=0;k++, l--, n1++, n2--)
                    {
                        if(arr[k][j]!='+' || k>=n)
                        {
                            break;
                        }
                        if(arr[l][j]!='+' || l<0)
                        {
                            break;
                        }
                         if(arr[i][n1]!='+' || n1>=m)
                        {
                            break;
                        }
                         if(arr[i][n2]!='+' || n2<0)
                        {
                            break;
                        }
                        c1++;
                    }
                    ll check=(c1*4)+1;
                    maxi=max(check,maxi);
                }
            }
        }
        cout<<maxi<<endl;
        }
        
    }
}

Information

Submit By
Type
Submission
Problem
P1143 Plus of Pluses
Contest
LU IUJPC : Sylhet Division 2024
Language
C++17 (G++ 13.2.0)
Submit At
2024-12-09 07:04:45
Judged At
2024-12-09 07:04:45
Judged By
Score
100
Total Time
1491ms
Peak Memory
4.586 MiB