Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 그래프
- 프로그래머스
- Mendix
- dfs
- 집합
- 매개변수 탐색
- 멘딕스
- 스택
- 정렬
- 자료구조
- 완전탐색
- SQL
- Recursion
- 반효경교수님
- domain model
- algorithm
- 백트래킹
- MySQL
- 알고리즘
- 트리
- 해시맵
- git
- microflow
- Sort
- 재귀
- 이분탐색
- lcap
- 가중치없는그래프
- Bruteforce
- 자바
Archives
- Today
- Total
mondegreen
[240419] 알고리즘 리부트 52일차 - 프로그래머스 롤 케이크 자르기 자바 본문
반응형
앞쪽과 뒤쪽으로 방향으로 순회하면서 각 인덱스 별로 몇개의 종류를 가지는지 set에 담고 set의 크기를 새로운 배열에 각각 넣어줬다. 그리고 경계가 되는 연속되는 두 인덱스의 값이 같을 경우 answer에 더해주는 방식으로 구현했다. 처음에는 앞쪽으로만 토핑의 수를 세고 매번 남은 토핑 종류를 세려고 했지만 인덱스 옮길 때마다 반복문을 최악의 경우 백만번의 인덱스를 매번 돌아줘야 하기 때문에 시간 초과가 발생한다. 따라서 아래 코드 처럼 미리 양방향으로 토핑 수를 세어주자.
import java.util.*;
class Solution {
public int solution(int[] topping) {
int answer = 0;
int len = topping.length;
int [] order = new int[len];
int [] reverseOrder = new int[len];
// 앞과 뒤에서부터 센 토핑의 가짓 수를 Set을 이용해서 구하고
HashSet<Integer> former = new HashSet<>();
HashSet<Integer> latter = new HashSet<>();
for(int t = 0; t < len; t++) {
former.add(topping[t]);
order[t] = former.size();
latter.add(topping[(topping.length-1)-t]);
reverseOrder[(topping.length-1)-t] = latter.size();
}
for(int i = 0; i<len-1; i++){
if(order[i]==reverseOrder[i+1]) answer++;
}
return answer;
}
}
반응형
'알고리즘 풀이 및 리뷰 > 프로그래머스' 카테고리의 다른 글
[240427] 알고리즘 리부트 55일차 - 프로그래머스 캐시 자바 (0) | 2024.04.27 |
---|---|
[240423] 알고리즘 리부트 54일차 - 프로그래머스 야근 지수 자바 (0) | 2024.04.23 |
[240418] 알고리즘 리부트 51일차 - 프로그래머스 무인도 여행 자바 (1) | 2024.04.18 |
[240418] 알고리즘 리부트 51일차 - 프로그래머스 택배상자 자바 (0) | 2024.04.18 |
[240417] 알고리즘 리부트 50일차 - 프로그래머스 모음사전 자바 (1) | 2024.04.18 |