김니은 
KimN's Blog
김니은 
  • 분류 전체보기
    • Algorithm
      • Programmers
    • Develop
      • Swift
      • Flask
      • RubyonRails
      • AWS
      • Ardunio
      • Vue
      • Node.js
      • Infra
      • CS
    • IT Story
      • Hackintosh
      • GitHub
      • IT Review

블로그 메뉴

  • 홈
  • 태그
  • 방명록

인기 글

태그

  • SWIFT
  • 항상 맨 위
  • Ruby
  • Code Snippet
  • Ruby on Rails
  • SWIFTUI
  • TOAST
  • 카카오 챗봇

최근 댓글

최근 글

티스토리

반응형
hELLO
김니은 

KimN's Blog

[프로그래머스] 가장 큰 정사각형 찾기 c++
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);
}
 

 

 

반응형
저작자표시 (새창열림)

'Algorithm > Programmers' 카테고리의 다른 글

[프로그래머스] 괄호 변환 c++ 2020 카카오  (0) 2022.06.05
[프로그래머스] 쿼드압축 후 개수 세기  (0) 2022.06.05
[프로그래머스] 폰켓몬 c++  (0) 2022.06.05
[프로그래머스] 올바른 괄호 c++  (0) 2022.06.05
[프로그래머스] 땅따먹기 c++  (0) 2022.06.05
    'Algorithm/Programmers' 카테고리의 다른 글
    • [프로그래머스] 괄호 변환 c++ 2020 카카오
    • [프로그래머스] 쿼드압축 후 개수 세기
    • [프로그래머스] 폰켓몬 c++
    • [프로그래머스] 올바른 괄호 c++
    김니은 
    김니은 

    티스토리툴바