inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

7-V

7-V 질문입니다.

249

hkt

작성한 질문수 6

0

안녕하세요 큰돌님!

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

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

http://boj.kr/a97107fe0c2d4574a2b852b398a10ecd

감사합니다.

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

c++ 코딩-테스트

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

감사합니다.

코딩살구클럽 문의

0

6

1

코딩살구클럽 승인

0

18

2

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

0

27

2

3-F 채점 관련 질문

0

23

1

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

0

28

2

코딩살구클럽 승인

0

41

2

코딩살구클럽승인

0

33

3

코딩살구클럽 승인

0

48

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

43

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

53

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

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

0

61

2

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

0

64

2

코딩살구클럽 로그인문제

0

78

3

코딩 살구 클럽 로그인 문제

0

82

2

2-J 채점관련 질문

0

65

3

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

0

77

1

살구클럽 아이디 없음 문제

0

76

1

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

0

60

2

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

0

57

1

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

1

74

2