인프런 커뮤니티 질문&답변

김상민님의 프로필 이미지
김상민

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

2-S

2-S dp 배열을 좀 더 이용해보려고 코드를 바꿔봤는데 틀렸습니다가 나오네요

해결된 질문

작성

·

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점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

 

김상민님의 프로필 이미지
김상민
질문자

항상 좋은 수업, 답변까지 감사합니다!

김상민님의 프로필 이미지
김상민

작성한 질문수

질문하기