해결된 질문
작성
·
171
0
아래는 맞는 코드입니다.
http://boj.kr/1b13bda362154df9b5be8a26cad57c96
이 코드를 개선해보려고 아래와 같이 코드를 짜보니 틀렸습니다가 나오네요.
http://boj.kr/a6cbb7ca3b214df386ebb96214bc2785
dp를 아직 잘 모르는데 선생님의 풀이를 보고 조금 더 횟수를 줄일 수 있지 않을까 해서 한번 바꿔봤는데요. 맞왜틀에 빠졌습니다... 도저히 혼자서는 이유를 찾을 수 없어서 질문드립니다!
답변 1
2
안녕하세요 상민님 ㅎㅎ
지금 보시면
for(int there : arr[here]) {
if(visited[there]) continue;
table[there] = dfs(there);
cnt += table[there];
}
해당 노드로 부터 뻗어나가는 노드의 table에 담으신 거잖아요.
아마 그렇게 해서 dfs를 줄이는 방법을 생각하신 거 같은데요.
생각은 너무나도 좋습니다. ㅎㅎ
다만
2 -> 1 -> 3 -> 4 -> 1
이렇게 되었을 때
1부터시작하게 되면.
table 1 : 3
table 3 : 2
table 4 : 1
이렇게 되겠죠?
근데 사실은 이게 정답이죠.
table 1 : 3
table 3 : 3
table 4 : 3
이러한 반례 때문에 틀린 것 같습니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
항상 좋은 수업, 답변까지 감사합니다!