히든퀘스트 브루트포스 질문
333
작성한 질문수 28
안녕하세요 선생님 브루트포스 히든퀘스트를 풀고 있는데요, 계속 시간초과가 떠서 질문드립니다.
재귀 완탐으로 풀었는데 시간초과가 뜨네요. 그래서 다른분들 풀이 구글링해서 봤는데 대부분 3중 for문 콤비네이션으로 해결했더라구요. 제 로직에는 문제가 없다고 생각했는데, 혹시 제 방법으로는 해결할 수 없는 문제인가요? 나름 가지치기도 했는데 안풀립니다ㅠㅠ
2798 블랙잭 문제입니다
http://boj.kr/22b25fa79ad74c69b0797537b4a7669f
답변 1
1
안녕하세요 명운님 ㅎㅎ
명운님의 로직은 타당합니다.
다만, 시간초과가 나는 것은요.
기저사례 부분을 보았을 때 함수호출을 조금은 더 많이 하게 되어서 시간초과가 나타나는 것 같습니다.
이렇게 조금만 바꾸시면 됩니다.
#include <iostream>
using namespace std;
int N, M, a[104], ret;
void go(int idx, int num, int _ret){
if(idx >= N) return;
//cout << idx << " : " << num << " : " << _ret << "\n";
if(num == 3){
if(_ret > M) return;
ret = max(ret, _ret);
return;
}
go(idx + 1, num + 1, _ret + a[idx + 1]);
go(idx + 1, num, _ret);
return;
}
int main(){
cin >> N >> M;
for(int i = 0; i < N; i++) cin >> a[i];
go(-1, 0, 0);
cout << ret << "\n";
return 0;
}
코드리뷰를 좀 드리면요
void go(int cnt, int sum, int chk) {
if (ret == M) return;이 문제는 M을 넘지 않아야 합니다. 즉, 넘으면 종료시키는 부분이 필요한데 이렇게 M과 같을 때 return을 하게 되는 경우의 수가 몇이나 될까요? 많은 경우의 수를 걸러내지 못합니다.
if (cnt == N) {
if (sum <= M && chk == 3) ret = max(ret, sum);
return;
}이렇게 되면 무조건 완탐을 했을 경우 중첩 if문이 작동됩니다.
가지치기를 못하는 코드입니다.
이 문제는 chk == 3일 때 체킹을 해야 합니다.
왜그러냐면 chk == 3일 때 체킹을 '먼저' 하게 되면 N까지 다 안돌아도 해당 부분을 확인하고 함수호출을 더이상 안할 수 있거든요.
나머지 부분은 괜찮습니다. ㅎㅎ
또 질문 있으시면 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다.
감사합니다.
코딩 살구 클럽 컴파일 에러
0
4
1
추천 문제
0
7
1
코딩살구클럽 승인
0
9
1
코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의
0
21
2
문제를 고민하는 시간 관련
0
26
2
코딩살구클럽
0
38
2
코딩살구클럽 문의
0
37
2
코딩살구클럽 승인
0
35
2
DP 경우의 수 설명이 이해가 되지 않습니다.
0
33
2
3-F 채점 관련 질문
0
31
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
33
2
코딩살구클럽 승인
0
45
2
코딩살구클럽승인
0
39
3
코딩살구클럽 승인
0
54
2
3-D 관련 질문
0
35
2
코살구 회원가입 문의
0
45
2
코살구 로그인 문제
0
65
2
3-A 문제 풀이 관련 질문
0
56
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
63
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
67
2
코딩살구클럽 로그인문제
0
85
3
코딩 살구 클럽 로그인 문제
0
86
2





