해결된 질문
작성
·
41
0
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
http://boj.kr/32d8365f752d4ea7a3ec61b9ad94f90c
안녕하세요 큰돌님. 저의 풀이는 combi 함수가 아닌 원복을 하며 완전탐색으로 풀이를 진행했습니다.
하지만 시간초과가 발생하여 어느 부분에서 시간 초과가 발생하는지, 그리고 시간초과가 발생하지 않을 라면 저의 코드에서 어떤 부분을 수정해야 하는지 알 수 있을까요??
항상 좋은 강의 해주셔서 감사드립니다 :)
답변 1
0
안녕하세요 찬민님 ㅎㅎ
for (auto it : chi)
{
if (visited[it.first][it.second]) continue;
visited[it.first][it.second] = 1;
select_chi.push_back(it);
go();
visited[it.first][it.second] = 0;
select_chi.pop_back();
}
이 코드를 보시면 이 재귀함수의 시간복잡도를 알 수 있는데요.
chi의 최대 크기는 13.
함수당 기저사례인 m까지 진행하므로 최대 13^m정도의 시간복잡도임을 알 수 있습니다.
여기서 m의 최대는 마찬가지로 13입니다. 즉, 13^13의 큰 시간복잡도를 가지기 때문에
시간초과가 발생하는 것 같습니다.
감사합니다.