inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-E

3-E 재귀 시간초과

266

it Ez

작성한 질문수 4

0

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

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

c++ 코딩-테스트

답변 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);

 

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

 

감사합니다.

코딩살구클럽 가입 문의

0

22

1

코딩 살구 클럽 컴파일 에러

0

16

1

추천 문제

0

17

1

코딩살구클럽 승인

0

21

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

30

2

문제를 고민하는 시간 관련

0

27

2

코딩살구클럽

0

42

2

코딩살구클럽 문의

0

44

2

코딩살구클럽 승인

0

37

2

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

0

35

2

3-F 채점 관련 질문

0

32

1

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

0

34

2

코딩살구클럽 승인

0

46

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

56

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

66

2

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

0

67

2

코딩살구클럽 로그인문제

0

85

3