백준 1932번의 동적계획법 문제를 풀었는데요
글쓴이: kmc04 / 작성시간: 화, 2019/01/29 - 11:33오후
#include <iostream> #include <algorithm> #include <cstring> using namespace std; int cost[1001][501]; int dp[1001][501]; int N; int dfs(int pre, int max_idx) { if(max_idx >= N) return 0; if(dp[pre][max_idx] != -1) return dp[pre][max_idx]; int m = 0; m = max(m,cost[pre][max_idx] + dfs(pre,max_idx+1)); m = max(m,cost[pre][max_idx] + dfs(pre+1,max_idx+1)); dp[pre][max_idx] = m; return m; } int main() { scanf("%d",&N); for(int i=0; i<N; i++) for(int j=0; j<=i; j++) scanf("%d",&cost[j][i]); memset(dp,-1,sizeof(dp)); printf("%d\n",dfs(0,0)); return 0; }
재귀호출 과정에서 dp 에 m이 어떤과정을 거쳐서 저장되는지 잘 모르겠습니다 ..
m = max(m,cost[pre][max_idx] + dfs(pre,max_idx+1));
m = max(m,cost[pre][max_idx] + dfs(pre+1,max_idx+1));
이렇게 두번 재귀호출을 하는데
둘 중에 큰값이 dp[pre][max_idx]에 저장되는 것인가요?
아니면 각각 별개로 저장되고 진행되고 저장되고 진행되고 하는것인가요
간략하게나마 설명해주실 고수분 부탁드립니다 ㅜㅜ
File attachments:
첨부 | 파일 크기 |
---|---|
![]() | 39.86 KB |
Forums:
"각각 별개로 저장되고 진행되고 저장되고 진행되고"가
"각각 별개로 저장되고 진행되고 저장되고 진행되고"가 무슨 뜻인지 모르겠습니다만, 코드만 보면 결국
- m 의 초기값
- cost[pre][max_idx] + dfs(pre,max_idx+1)
- cost[pre][max_idx] + dfs(pre+1,max_idx+1)
셋 중의 가장 큰 값이 m에 들어가고 다시 dp[pre][max_idx]에 들어가겠죠.
물론 dfs(pre,max_idx+1)을 구하려니 다시 입력의 다음 줄에서 같은 과정을 먼저 수행할 테고, 그러자면 또 다다음 줄에서 같은 과정을 먼저... 이러다보면 결국 제일 아랫줄부터 구해서 위로 쌓아올리게 될 거고요.
프린트문 하나만 추가해서 천천히 따라가보시면 이해하시는데 도움이 될 것 같습니다.
좋은 하루 되세요!
백준 님에게 물어보세요.
백준 님에게 물어보세요.
텍스트로 칠 수 있는 건 화면 캡처해서 첨부하는 대신 직접 쳐서 본문에 넣는 게 좋습니다.
세벌 https://sebuls.blogspot.kr/
난 도저히 모르겠음.
난 도저히 모르겠음.
세벌의 답변이 shint의 그것과 비교했을 때, 정말 나은지.....
세벌이 shint에게, 그런 답변 달지 마라 할 수 있는지......
동족혐오인가보죠 뭐. 그런 건 아무래도 상관없습니다.
동족혐오인가보죠 뭐. 그런 건 아무래도 상관없습니다.
양질의 답변을 바란다면, 양질의 답변을 쓰면 되는거에요.
뭐 맨날 보는 저로서는 그냥 저 사람 스타일인갑다
뭐 맨날 보는 저로서는 그냥 저 사람 스타일인갑다 하는데, 생전 첨 오는 사람이 질문했다가 "그건 원저자한테 물어보시구요 코드는 이미지로 올리지 마세요" 같은 답변 들으면 좌절해서 다시 안 올까봐 좀 안쓰럽긴 합니다.
...뭐 하긴 코더는 원래 강하게 커야 하니 그정도로 좌절할 거면 그만두는 게 나을지... 음 이건 아닌가? -_-
댓글 달기