작성
·
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점은 제게 큰 힘이 됩니다.
감사합니다.