알고리즘 공부
[백준 16987번] 여행 가자 - java
철매존
2024. 11. 29. 02:25
728x90
반응형
문제 설명
1. 테스트용 계란을 왼쪽부터 집는다.
2. 다른 계란하고 부딪혀본다. (내구도는 무게에 의해 깎이고 내구도가 0보다 작거나 같으면 깨짐)
3. 모든 경우에서 최대한 많은 계란을 깬다면 그 숫자는?
풀이 과정
1. BF - DFS + 백트래킹으로 풀면 된다.
2. 보면 결국 어떤 계란을 집었을 때에 하나씩 테스트하고, 그렇게 마지막까지 도달하면 하나의 경우를 테스트하는 것이다(BF - DFS)
3. 그리고 그 테스트가 끝나면 아무일 없던 것처럼 계란을 돌려놓는다(백트래킹)
4. 재귀함수를 통해서 구하고 ans를 구해주면 된다.
코드
import java.util.*;
public class Main
{
private static List<Egg> eggList = new ArrayList<>();
private static int size;
private static int ans = 0;
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int N = sc.nextInt();
for(int i=0; i<N; i++) {
int durablilty = sc.nextInt();
int weight = sc.nextInt();
eggList.add(new Egg(durablilty, weight));
}
// 마지막 계란의 위치를 기억한다.
size = N;
BF(0, 0);
System.out.println(ans);
}
private static void BF(int index, int count) {
// 모든 위치에 도달할 때마다 결과값을 저장해도 상관없다. 어차피 마지막까지 깨는 모든 경우를 다 포함
ans = Math.max(ans, count);
// 맨 마지막 계란을 테스트한 후에는 끝
if(index == size) {
return;
}
// 지금 드는 계란
Egg nowEgg = eggList.get(index);
int durablilty = nowEgg.durablilty;
int weight = nowEgg.weight;
// 깨져있으면 다음꺼 확인
if(durablilty <= 0) {
BF(index+1, count);
return;
}
for(int i=0; i<size; i++) {
if (index == i) continue; // 지금계란은 테스트 불가
int counter = count; // 몇개나 깼는지 확인하기 위함
// 깨볼 계란
Egg targetEgg = eggList.get(i);
int targetDur = targetEgg.durablilty;
int targetWeight = targetEgg.weight;
if(targetDur <= 0) continue; // 이미 깨져있으면 테스트하지 않는다.
// 두드려보고
durablilty -= targetWeight;
targetDur -= weight;
// 꺠졌으면 체크
if(targetDur <= 0) counter++;
if(durablilty <= 0) counter++;
// 그 계란의 정보를 저장하고
eggList.set(index, new Egg(durablilty, weight));
eggList.set(i, new Egg(targetDur, targetWeight));
// 이 계란을 테스트한 후에는 기존 계란은 냅두고 다시 다른 계란으로 테스트한다 (DFS)
BF(index+1, counter);
// 위의 DFS가 끝났으면 다른 테스트를 위해 아무일 없던것처럼 세팅
durablilty += targetWeight;
targetDur += weight;
eggList.set(index, new Egg(durablilty, weight));
eggList.set(i, new Egg(targetDur, targetWeight));
}
}
}
class Egg {
int durablilty;
int weight;
public Egg(int durablilty, int weight) {
this.durablilty = durablilty;
this.weight = weight;
}
}
반응형