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

it Ez님의 프로필 이미지
it Ez

작성한 질문수

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

3-E

3-E 재귀 시간초과

작성

·

191

0

안녕하세요! 항상 강의 잘 보고 있습니다.
다름이 아니라, 아래 링크처럼 재귀 + 백트래킹으로 풀었음에도 불구하고 시간초과가 나는 이유가 감이 안옵니다.

어디 부분 때문에 시간 초과가 일어나는 것일까요??
https://www.acmicpc.net/source/share/a30df43331f9487eb25d43dfa7a24e95

답변 1

0

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

안녕하세요 ㅎㅎ

백트래킹도 하구 잘 하셨는데요. ㅎㅎ

 

이 코드는 사실은 BFS보다는 안좋은 코드입니다.

image예를 들어 이런 반례가 있죠.

수강생님 코드는 이 경우에 k번 탐색하게 됩니다.

만약 BFS로 탐색하게 되면 2번인데 말이죠.

    if(cnt >= ret) return cnt;

이렇게 정점탐색을 최소화해도 불필요한 부분을 탐색할 수 있는 반례가 있는 것은 맞기 때문에 해당부분에 걸려서 시간초과가 나는 것 같습니다.

그리고 3 60 60 60을 넣어보면 너무 오래걸려서 답자체가 안뜹니다. (제 로컬에서 실행시 - 맥북프로)

 

그리고 이부분 에러 발생되지 않나요?


        int atk[vec.size()] = {0,};
        copy(atk_all, atk_all+vec.size(), atk);

 

에러가 발생되지 않는다면 컴파일러가 어떤 환경인지 알 수 있을까요?

 

감사합니다.

it Ez님의 프로필 이미지
it Ez

작성한 질문수

질문하기