inflearn logo
강의

講義

知識共有

10週間完成 C++ コーディングテスト | アルゴリズムコーディングテスト

7-V

7-V 문제 질문

212

sgo7225164

投稿した質問数 3

0

안녕하세요 큰돌쌤!

 

문제를 풀다가 막혀서 질문드립니다!

 

http://boj.kr/54155bff977f43b3a75c1a59fc22430d

 

저는 ‘dp[현재위치][이동시간] = 모금액’ 이렇게 두고 활용했는데 1퍼 진행되고 틀렸습니다.

 

어떤 부분이 잘못되었는지 가르쳐주실수 있나요?

c++ 코딩-테스트 7-v

回答 2

0

kundol

안녕하세요 준영님 ㅎㅎ

제가 답변드리려고 했는데 잘 생각하셨네요. ㅎㅎ

    ret = -INF;
    ret = max(go(idx+1, sumFee+walk[idx].fee, walk[idx].time), go(idx+1, sumFee+ride[idx].fee, sumTime+ride[idx].time));
    return ret;
}

말씀하신 것 처럼 이부분이 문제입니다.

DP라는 것은 로컬 optimum이 쌓여서 글로벌한 optimum으로 만드는 것이 핵심입니다.

 

즉, 각 정점은 해당 정점에서의 최적의 해를 담고 있어야 합니다.

그러나 준영님의 코드를 보면

go(idx+1, sumFee+walk[idx].fee, walk[idx].time)
go(idx+1, sumFee+ride[idx].fee, sumTime+ride[idx].time)

이 둘중의 max값을 해당 idx에 담고 있는데요. 얼핏보면 괜찮아보이지만..

 

이런 예를 생각하면 됩니다.

a -> b -> c -> d

d까지 가서 최대의 값을 가짐 -> c로 감 -> b로 감 -> a로 감.. 이렇게 해서 a가 정상적으로 max값을 출력하게 되지만..

DP배열을 보게 되면

아마 이런식으로 담겨있을 가능성이 높습니다.

dp[a] = 100

dp[b] = 100

dp[c] = 100

dp[d] = 100

 

즉, 간단한 그래프라면.. 어느정도는 될 거 같은데요. 복잡한 그래프라면 이 DP코드는 DP배열을 온전한 값으로 채우지를 못합니다. 그렇게 채우지를 못하고 해당 DP 배열끼리 비교도 안되구요.

그래서 틀리는 것 같습니다.


    if(_time - a[here]._time >= 0)ret = max(ret, go(here + 1, _time - a[here]._time) + a[here].pay); 
    if(_time - b[here]._time >= 0)ret = max(ret, go(here + 1, _time - b[here]._time) + b[here].pay); 

이런식으로 어떠한 가중치를 밖으로 빼서 해당 정점에서의 local optmimum을 만들고 그걸 기반으로 비교하게 만들어야 합니다.

즉.. 이런식으로 쌓이게 만들어야 합니다. 정점을 갈 때 + 가 되는 형식으로요 ㅎㅎ

dp[a] = 20

dp[b] = 50

dp[c] = 80

dp[d] = 100

 

하지만 나머지 부분이나 코드 구조는 전체적으로 깔끔하고 좋게 잘 짜셨습니다. ㅎㅎ

제가 말씀 드린 부분만 생각하시면 될 거 같아요.

 


또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

0

sgo7225164

큰돌님 코드를 다시 생각해서 큰돌님 코드를 따라갔고 어떤 부분이 문제였는지 확인했습니다.

 

1) dp의 값이 올바르게 저장되지 못하고 있었음.

-> idx를 n까지 탐색하면서 리턴한 값이 되돌아오면서 관련된 dp값들을 전부 그 값으로 만들게되면서 다시 탐색해야하는데 dp에 저장된 값이 문제가 있었음.

 

2) 대소비교를 해서 문제를 해결하려 했으나, dp자체에 값이 잘못저장되어있는 문제로 해결되지 않았음.

 

감사합니다.

코딩 살구 클럽 Python 지원 가능 여부

0

31

1

살구클럽 아이디 없음 문제

0

34

1

1-O 코딩살구클럽 채점관련 질문

0

35

2

히든 테스트 케이스가 사라졌습니다

0

30

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

43

2

살구 클럽 채점 관련 문의(테스트 케이스)

0

41

2

1-H 문제 채점하기 오류

0

38

3

코딩살구클럽 2주차 2-L 문제 채점하기 오류

0

38

2

살구 클럽 채점 관련 문의

0

50

2

코딩 살구 클럽 실전 세션

0

45

2

코딩살구클럽 채점 관련 질문

0

42

2

코딩살구클럽 컴파일에러

0

70

2

5-B

0

46

2

4 - A

0

49

2

코딩살구클럽 입장이 안됩니다

0

118

2

4-F 경우의 수 질문입니다.

0

52

2

코딩살구클럽 가입이 안됩니다.

0

112

2

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

75

1

교안 158페이지 문의드립니다

0

53

2

코딩살구클럽 관련 건의사항

0

157

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

54

1

진행 방법 질문드립니다!

0

100

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

65

2

2주차 개념#12 트리 순회

0

34

2