inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-S

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

해결된 질문

232

김상민

작성한 질문수 17

0

아래는 맞는 코드입니다.

http://boj.kr/1b13bda362154df9b5be8a26cad57c96
이 코드를 개선해보려고 아래와 같이 코드를 짜보니 틀렸습니다가 나오네요.
http://boj.kr/a6cbb7ca3b214df386ebb96214bc2785
dp를 아직 잘 모르는데 선생님의 풀이를 보고 조금 더 횟수를 줄일 수 있지 않을까 해서 한번 바꿔봤는데요. 맞왜틀에 빠졌습니다... 도저히 혼자서는 이유를 찾을 수 없어서 질문드립니다!

c++ 코딩-테스트

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

감사합니다.

강사 큰돌 올림.

 

0

김상민

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

코딩 살구 클럽 컴파일 에러

0

4

1

추천 문제

0

7

1

코딩살구클럽 승인

0

9

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

21

2

문제를 고민하는 시간 관련

0

26

2

코딩살구클럽

0

38

2

코딩살구클럽 문의

0

37

2

코딩살구클럽 승인

0

35

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

33

2

3-F 채점 관련 질문

0

31

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

33

2

코딩살구클럽 승인

0

45

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

54

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

63

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3

코딩 살구 클럽 로그인 문제

0

86

2