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

hkt님의 프로필 이미지
hkt

작성한 질문수

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

7-V

7-V 질문입니다.

작성

·

201

0

안녕하세요 큰돌님!

기존 답안과 차이점은 조건에 해당하는 재귀함수만 호출하는 대신, 함수 시작(line13) 에서 시간을 검사하여, 배제한다~~!! 할 수 있도록 하였는데요...

왜 틀린 답안인지... 가르침 부탁드립니다 ㅎㅎ

http://boj.kr/a97107fe0c2d4574a2b852b398a10ecd

감사합니다.

- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.

답변 1

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 hkt님ㅎㅎ

네 그렇게 해도 맞습니다. 괜찮은 로직이에요. 다만, 조금은 틀린 부분이 있습니다.

#include <bits/stdc++.h> 
using namespace std; 
typedef long long ll; 
int n, k, dp[101][100001]; 
struct B{
    int _time, pay; 
}; 
B a[101], b[101];

int go(int here, int _time){
    if(_time < 0) return -1e9;
    if(here == n) return 0;  
    int &ret = dp[here][_time]; 
    if(ret) return ret; 
    ret = -1e6;
    ret = max(ret, go(here + 1, _time - a[here]._time) + a[here].pay); 
    ret = max(ret, go(here + 1, _time - b[here]._time) + b[here].pay); 
    return ret; 
}
int main(){
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL); 
    cin >> n >> k; 
    for(int i = 0; i < n; i++){
        cin >> a[i]._time >> a[i].pay >> b[i]._time >> b[i].pay; 
    } 
    cout << go(0, k) << "\n"; 
    return 0;
}

이렇게 한번 고쳐보시겠어요?

 

또 질문 있으시면 질문 부탁드립니다.

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

감사합니다.

hkt님의 프로필 이미지
hkt

작성한 질문수

질문하기