60026 양손에 V

시간 제한: 2초 메모리 제한: 1024MB

문제

각 격자가 흰색 또는 검은색으로 칠해져 있는 NNMM열의 격자판이 주어진다.

다음과 같은 행동을 “V자 색칠하기” 라 하자:

  1. 흰색 격자를 하나 선택한다.
  2. 선택한 격자부터 시작하여 왼쪽 위 대각선을 따라 움직이면서 흰색이 아닌 격자가 나오거나 외부로 빠져나가기 전까지의 격자들을 모두 파란색으로 칠한다.
  3. 선택한 격자의 한 칸 오른쪽 위 격자부터 시작하여 오른쪽 위 대각선을 따라 움직이면서 흰색이 아닌 격자가 나오거나 외부로 빠져나가기 전까지의 격자들을 모두 파란색으로 칠한다.

“V자 색칠하기”를 두 번 했을 때 가능한 파란색 격자의 최대 개수를 구하여라.

예를 들어, 다음과 같은 격자판이 주어졌다 하자.

5행 5열의 격자에서 V자 색칠하기를 한 후 격자판의 상태는 다음과 같다.

그 후, 5행 9열의 격자에서 V자 색칠하기를 하면 다음과 같이 총 11개의 격자가 파란색으로 칠해진다.

반면, 5행 9열의 격자에서 먼저 V자 색칠하기를 한 후 5행 5열의 격자에서 V자 색칠하기를 하면 다음과 같이 총 13개의 격자가 파란색으로 칠해진다.

두 번의 V자 색칠하기로 13개보다 많은 격자를 파란색으로 칠하는 방법은 존재하지 않으므로, 주어진 격자판에서의 답은 13이 된다.

입력

첫 번째 줄에 NNMM이 공백으로 구분되어 주어진다.

두 번째 줄부터 NN개의 줄에 걸쳐 격자판에 대한 정보가 주어진다. 각 줄에는 00 또는 11로 이루어진 길이 MM인 문자열이 주어진다. NN개의 줄 중 ii번째 줄의 jj번째 문자가 11이면 격자판에서 iijj열의 격자가 흰색, 00이면 검은색임을 뜻한다. (1iN,1jM1 \le i \le N, 1 \le j \le M)

출력

첫 번째 줄에 가능한 파란색 격자의 최대 개수를 출력한다.

제한

  • 1N,M30001 \le N, M \le 3\,000
  • 주어지는 격자판에서 흰색 격자는 최소 2개 존재한다.

서브태스크

111N,M20N, M \le 20
220N,M100N, M \le 100
324N,M500N, M \le 500
445추가 제약 조건 없음.

예제 입출력

예제 입력 1
5 11
10001000000
01000100000
00100110001
00010101010
00001000100
예제 출력 1
13
예제 입력 2
3 3
111
111
111
예제 출력 2
6

출처

올림피아드 한국정보올림피아드 KOI 2024 2차 초등부 4번
solution.cpp
에디터 불러오는 중...