일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 |
Tags
- Spring ipfs
- java 1238
- 자바 백준 팩토리얼 개수
- nodejs rabbitmq
- java 백준 1509
- 백준 1504 java
- spring mongodb
- kotiln const val
- 백준 특정한 최단 경로
- Java Call By Refernce
- 백준 2252 줄세우기
- 익명 객체 @transactional
- 자바 1676
- ipfs bean
- mongodb lookup
- java 파티
- go
- spring mongodb switch
- java 팩토리얼 개수
- 전략 패턴이란
- spring mongoTemplate
- kotiln const
- spring mongoTemplate switch
- ipfs singletone
- kotiln functional interface
- javav 1676
- 안정해시
- rabbitmq 싱글톤
- 백준 연결요소 자바
- java 1509
Archives
- Today
- Total
공부 흔적남기기
[JAVA] 백준 가장 큰 정사각형 1915 본문
728x90
반응형
가장 큰 정사각형을 구하기 위해서는 BFS를 통해서 찾을 수도 있겠지만 n,m이 최대 1000이기때문에
시간내에 가장 큰 BFS를 찾는 것은 불가능할 것이다.
따라서 다이나믹 프로그래밍을 사용해야한다.
해당 2차원배열에서 가장큰 정사각형을 찾을때
dp[y][x] x는 정사각형 오른쪽 아래에 값으로 현재 정사각형의 최대 크기를 나타낸다.
dy[y-1][x-1], dy[y-1][x], dy[y][x-1] 에서 가장 작은것에 +1 한것이 dy[y][x]임을 알 수 있다.
// Online Java Compiler
// Use this editor to write, compile and run your Java code online
import java.util.*;
import java.io.*;
class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
String[] input = br.readLine().split(" ");
int n = Integer.parseInt(input[0]);
int m = Integer.parseInt(input[1]);
int[][] board = new int[n][m];
for(int i =0; i<n; i++){
board[i] = Arrays.stream(br.readLine().split("")).mapToInt(Integer::parseInt).toArray();
}
int answer = 0;
for(int i =0; i<m; i++){
if(board[0][i] ==1){
answer = 1;
break;
}
}
for(int i =0; i<n; i++){
if(board[i][0] ==1){
answer = 1;
break;
}
}
for(int i =1; i<n; i++){
for(int j =1; j<m; j++){
if(board[i][j] != 0){
int a = board[i-1][j-1];
int b = board[i-1][j];
int c = board[i][j-1];
if(a == 0 || b== 0 || c == 0){
continue;
}
board[i][j] = Math.min(a, Math.min(b,c)) +1;
answer = Math.max(Math.max(1,answer), board[i][j]);
}
}
}
bw.write(answer * answer + "");
bw.flush();
bw.close();
br.close();
}
}
728x90
반응형
'코테 > 백준' 카테고리의 다른 글
[JAVA] 백준 숫자 정사각형 1051 (0) | 2025.03.31 |
---|---|
[JAVA] 백준 택배 1719 (0) | 2025.03.23 |
[JAVA] 백준 1509 팰린드롬 분할 (0) | 2025.03.14 |
[JAVA] 파티 1238 (0) | 2025.03.06 |
[JAVA] 백준 특정한 최단 경로 1504 (0) | 2024.12.01 |