티스토리 뷰
728x90
반응형
문제 링크
programmers.co.kr/learn/courses/30/lessons/68936
문제 풀이
제가 예전에 풀었던 색종이 만들기와 거의똑같은 문제였죠.
계속해서 4등분을해서 같은지 비교해가며 풀면 쉽게 풀어낼수 있습니다.
소스 코드
class Solution {
public static int[] solution(int[][] arr) {
int[] answer = new int [2];
String ans = sol(arr, arr.length, 0, 0);
for (char cha : ans.toCharArray()) answer[cha-'0']++;
return answer;
}
static String sol(int [][] arr, int n , int x , int y) {
if(test(arr, n, x, y)) {
return arr[x][y]+"";
}else {
return sol(arr, n/2, x, y) +sol(arr, n/2, x, y+n/2) +sol(arr, n/2, x+n/2, y) +sol(arr, n/2, x+n/2, y+n/2);
}
}
static boolean test(int [][] arr, int n , int x , int y) {
for (int i = x; i < x+n; i++) {
for (int j = y; j < y+n; j++) {
if(arr[x][y]!=arr[i][j]) return false;
}
}
return true;
}
}
728x90
반응형
250x250
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 19236
- 문자열 압축
- 삼성 코테
- 카카오 인턴십
- 삼성기출
- 커링
- 프로그래머스
- javascript
- 제네릭 타입
- 삼각달팽이
- 오버로딩
- spring cache
- RGB거리
- for of
- 키패드 누르기
- 백준
- 날짜 유효성
- vaild
- 제네릭(Generic)
- 가장 큰 수
- java
- 청소년상어
- 01타일
- 39회차
- 반례
- 카카오 코딩 테스트
- 1629
- local cache
- DP
- yyyy-MM-dd
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 31 |
글 보관함