/ SeriousOJ /

Record Detail

Accepted


  
# Status Time Cost Memory Cost
#1 Accepted 3ms 8.527 MiB
#2 Accepted 15ms 14.797 MiB
#3 Accepted 10ms 12.703 MiB
#4 Accepted 11ms 14.562 MiB
#5 Accepted 13ms 16.75 MiB
#6 Accepted 11ms 14.797 MiB
#7 Accepted 27ms 14.941 MiB
#8 Accepted 43ms 14.98 MiB
#9 Accepted 53ms 39.77 MiB
#10 Accepted 47ms 21.086 MiB
#11 Accepted 30ms 22.578 MiB
#12 Accepted 50ms 72.285 MiB
#13 Accepted 51ms 75.219 MiB
#14 Accepted 50ms 70.977 MiB
#15 Accepted 49ms 74.207 MiB
#16 Accepted 50ms 71.891 MiB
#17 Accepted 49ms 73.336 MiB
#18 Accepted 51ms 75.699 MiB
#19 Accepted 53ms 70.848 MiB
#20 Accepted 49ms 73.293 MiB
#21 Accepted 152ms 127.832 MiB
#22 Accepted 152ms 127.844 MiB
#23 Accepted 151ms 127.84 MiB
#24 Accepted 148ms 127.832 MiB
#25 Accepted 190ms 128.02 MiB
#26 Accepted 156ms 127.727 MiB
#27 Accepted 148ms 127.711 MiB
#28 Accepted 149ms 127.77 MiB
#29 Accepted 151ms 127.785 MiB
#30 Accepted 151ms 127.77 MiB

Code

//SUST_ZadeedBoss_Fanclub
//code_korlei_life_ase
//na_korle_lifeNai

#include<bits/stdc++.h>
using namespace std;
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace __gnu_pbds;
template <typename T> using o_set = tree<T, null_type, less_equal<T>, rb_tree_tag, tree_order_statistics_node_update>;
#define int long long
#define double long double
#define all(x) x.begin(), x.end()
#define rall(x) x.rbegin(), x.rend()
mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count()); 
const int N = 2010;
int dpr[N][N];
int dpl[N][N];
int dpu[N][N];
int dpd[N][N];
char inp[N][N];
void solve ()
{

	int n, m; cin >>n >>m; n++; m++;
	for (int i=1; i<n; i++)
	{
		for (int j=1; j<m; j++)
		{
			cin >>inp[i][j];
			// cout <<inp[i][j] <<" ";
		}
		// cout <<"\n";
	}
	for (int i=0; i<=n; i++)
	{
		for (int j=0; j<=m; j++)
		{
			dpl[i][j] = dpr[i][j] = dpd[i][j] = dpu[i][j] = 0;
		}
	}
	for (int i=1; i<n; i++)
	{
		for (int j=1; j<m; j++)
		{
			dpr[i][j] = (inp[i][j] == '+' ? dpr[i][j-1] + 1 : 0);
		}
	}

	for (int i=1; i<n; i++)
	{
		for (int j=m-1; j; j--)
		{
			dpl[i][j] = (inp[i][j] == '+' ? dpl[i][j+1] + 1 : 0);
		}
	}
	for (int i=1; i<m; i++)
	{
		for (int j=1; j<n; j++)
		{
			dpd[j][i] = (inp[j][i] == '+' ? dpd[j-1][i] + 1 : 0);
		}
	}

	for (int i=1; i<m; i++)
	{
		for (int j=n-1; j; j--)
		{
			dpu[j][i] = (inp[j][i] == '+' ? dpu[j+1][i] + 1 : 0);
		}
	}
	int ans = 0;
	for (int i=1; i<n; i++)
	{
		for (int j=1; j<m; j++)
		{
			if (inp[i][j] != '+') continue;
			int up = dpd[i][j] - 1;
			int down = dpu[i][j] - 1;
			int left = dpr[i][j] - 1;
			int right = dpl[i][j] - 1;
			// if (i==3 && j==2) cout <<up <<" " <<down <<" " <<left <<" " <<right <<"\n";
			ans = max(ans, (min({left, right, up, down})) * 4 + 1);
		}
	}
	cout <<ans <<"\n";




}

signed main()
{

	ios_base::sync_with_stdio(0);
	cin.tie(NULL);

	int TCASE = 1;
	cin >> TCASE;

	for (int tcase = 1; tcase <= TCASE; tcase++)
	{
		solve();
	}

}

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 06:34:04
Judged At
2024-12-09 06:34:04
Judged By
Score
100
Total Time
190ms
Peak Memory
128.02 MiB