Algorithm/Programmers
[프로그래머스] 가장 큰 정사각형 찾기 c++
김니은
2022. 6. 5. 20:01
반응형
문제 설명
1와 0로 채워진 표(board)가 있습니다. 표 1칸은 1 x 1 의 정사각형으로 이루어져 있습니다. 표에서 1로 이루어진 가장 큰 정사각형을 찾아 넓이를 return 하는 solution 함수를 완성해 주세요. (단, 정사각형이란 축에 평행한 정사각형을 말합니다.)
예를 들어

가 있다면 가장 큰 정사각형은

가 되며 넓이는 9가 되므로 9를 반환해 주면 됩니다.
제한사항
표(board)는 2차원 배열로 주어집니다.
표(board)의 행(row)의 크기 : 1,000 이하의 자연수
표(board)의 열(column)의 크기 : 1,000 이하의 자연수
표(board)의 값은 1또는 0으로만 이루어져 있습니다.
입출력 예
board
|
answer
|
[[0,1,1,1],[1,1,1,1],[1,1,1,1],[0,0,1,0]]
|
9
|
[[0,0,1,1],[1,1,1,1]]
|
4
|
#include <iostream>
#include <vector>
#include <cstring>
#include <cmath>
using namespace std;
int solution(vector<vector<int>> board) {
int answer = 0;
int check[1001][1001];
memset(check, 0, sizeof(check));
for (int i = 0; i < board.size(); i++)
for (int j = 0; j < board[0].size(); j++)
check[i + 1][j + 1] = board[i][j];
for (int i = 1; i <= board.size(); i++)
for (int j = 1; j <= board[0].size(); j++)
if (check[i][j] != 0) {
check[i][j] = min(min(check[i - 1][j], check[i][j - 1]), check[i - 1][j - 1]) + 1;
answer = max(answer, check[i][j]);
}
return pow(answer, 2);
}
반응형