동전교환 문제 풀이 개선
425
작성한 질문수 2
동전교환 문제 풀이 좀 더 개선이 가능할까요??
입력이
3
1 2 3
500
이라고 할 때 재귀가 많이 호출되서? 답을 찾을 기미가 안보이는데요.
혹시 DFS 방식으로 이 문제 개선이 가능한가요??
강의를 안보고 약간 무식한 BFS 방식으로 풀었을 때 정답 통과되고 위 문제도 해결은 가능한데 이런 종류의 문제 풀 때 DFS 방식으로 푸는게 맞는지 궁금합니다.
질문이 길어졌습니다(_)(_)
- BFS
import java.util.LinkedList;
import java.util.Scanner;
public class Main {
public static int n;
public static int m;
public static int[] chk = new int[501];
public int BFS(int idx, int[] arr) {
LinkedList<Integer> Q = new LinkedList<>();
Q.offer(arr[idx]);
int L = 1;
while (!Q.isEmpty()) {
int len = Q.size();
for (int i = 0; i < len; i++) {
int k = Q.poll();
if (k == m) return L;
for (int j = 0; j < n; j++) {
int x = arr[j] + k;
if (x == m) return L + 1;
if (x <= 500 && chk[x] == 0) {
Q.offer(x);
chk[x] = 1;
}
}
}
L++;
}
return Integer.MAX_VALUE;
}
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
n = scanner.nextInt();
int[] arr = new int[n];
for (int i = 0; i < n; i++) {
arr[i] = scanner.nextInt();
}
m = scanner.nextInt();
Main T = new Main();
int answer = Integer.MAX_VALUE;
for (int i = 0; i < n; i++) {
answer = Math.min(T.BFS(i, arr), answer);
chk = new int[501];
}
System.out.print(answer);
}
}
답변 1
안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.
0
71
2
갑자기 채점 사이트가 바뀌었어요
0
50
1
문제 리스트 페이지
0
43
1
채점 사이트 관련 질문드립니다
0
41
1
봉우리 문제 질문입니다
0
102
2
씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?
0
73
0
이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?
0
78
0
가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법
0
76
1
좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ
0
94
2
6-7 강의에서
0
53
1
6-6. 장난꾸러기 질문 있습니다.
0
50
1
강의 수강후 코딩테스트
0
126
1
answer 변수 사용 여부
0
50
1
2중 for문
1
96
2
2-11. 임시반장정하기 (Runtime Error)
0
67
1
혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?
0
75
1
이런 풀이는 어떨까요
0
50
1
자바 스트림 방식의 효율성 질문 드립니다.
0
62
1
알고리즘 자료 구조들..
0
68
1
StringBuilder vs BufferdWriter
0
53
1
원더랜드(프림)
0
55
1
이런 코드는 어떤가요?
0
66
1
bfs 풀이
0
62
1
병합정렬
0
58
1





