[문제 풀이] 낙 곡 P1169 [ZJOI 2007] 바둑판 제작 (좌표 DP + 현 선법)
사고의 방향
역시 절강성 은 보통 이 아니다.
지금까지 들 어 본 적 이 없 는 알고리즘 현 선 법 을 사용 합 니 다.
이른바 현 선법 이란 하나의 선 (길이 임 의) 으로 행렬 에서 이 선 이 도달 할 수 있 는 가장 왼쪽 과 가장 오른쪽, 그리고 이 선의 길 이 를 판단 하면 이 행렬 의 최대 치 를 얻 을 수 있다.
그러면 세 개의 배열 을 정의 하 겠 습 니 다.
l [i] [j] 는 (i, j) 맨 왼쪽 좌표 에 도달 할 수 있 음 을 나타 낸다.
r [i] [j] 는 (i, j) 맨 오른쪽 좌표 에 도달 할 수 있 음 을 나타 낸다.
up [i] [j] 는 (i, j) 위로 최대 거리 즉 선의 길 이 를 표시 합 니 다.
그러면 상태 전이 방정식 은 다음 과 같다.
l[i][j]=max(l[i][j],l[i-1][j]);// ( )
r[i][j]=min(r[i][j],r[i-1][j]);//
up[i][j]=up[i-1][j]+1;//
마지막 으로 정사각형 과 사각형 (장방형) 의 최대 면적 을 통계 한다.
코드
#include
using namespace std;
#define maxn 2020
int map[maxn][maxn],l[maxn][maxn],r[maxn][maxn],up[maxn][maxn];
int n,m,ans1,ans2;
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
cin>>map[i][j];
l[i][j]=r[i][j]=j;//
up[i][j]=1;// 1
}
for(int i=1;i<=n;i++)
for(int j=2;j<=m;j++)//
if(map[i][j]!=map[i][j-1]) l[i][j]=l[i][j-1];
for(int i=1;i<=n;i++)
for(int j=m-1;j>=1;j--)//
if(map[i][j]!=map[i][j+1]) r[i][j]=r[i][j+1];
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
{
if(i>1&&map[i][j]!=map[i-1][j])//
{
l[i][j]=max(l[i][j],l[i-1][j]);//
r[i][j]=min(r[i][j],r[i-1][j]);//
up[i][j]=up[i-1][j]+1;// +1
}
int a=r[i][j]-l[i][j]+1;//
int b=min(a,up[i][j]);//
ans1=max(ans1,b*b);//
ans2=max(ans2,a*up[i][j]);//
}
cout<ans2;
}
다음으로 전송:https://www.cnblogs.com/BrokenString/p/9911692.html
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.