페이지가 로드되지 않나요? 여기를 눌러보면 고쳐질 수도 있어요.
Placeholder

#8024
서브태스크

양손에 V 2초 1024MB

문제

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

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

  1. 흰색 격자를 하나 선택한다.

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

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

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

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

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

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

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

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

제약 조건

  • 1 \le N, M \le 3,000 

  • 주어지는 격자판에서 흰색 격자는 최소 2개 존재한다.


입력

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

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


출력

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


부분문제

번호 점수 조건
#111점

N, M \le 20

#220점

N, M \le 100

#324점

N, M \le 500 

#445점

추가 제약 조건 없음.


예제1

입력
511
10001000000
01000100000
00100110001
00010101010
00001000100
출력
13

예제2

입력
33
111
111
111
출력
6

태그


출처

2024 KOI 2차 초4

역링크