인프런 커뮤니티 질문&답변
3-A 치킨 배달 시간초과 관련 질문 입니다!
작성
·
281
0
http://boj.kr/5b5feb84a65f44c19188df5fbe697fe6선생님의 풀이와 크게 다르지 않은거 같은데 어디서 시간초과가 나는지 잘모르겠습니다...
답변 2
0
큰돌
지식공유자
안녕하세요 윤교님 ㅎㅎ
void go(int count) {
if (count == m) {
//거리계산
minDis = min(minDis, calcu());
return;
}
for (int i = 0; i < chicken.size();i++) {
selectChicken.push_back(make_pair(chicken[i].first,chicken[i].second));
go(count + 1);
selectChicken.pop_back();
}
}이부분이 가장 다릅니다.
저거 go함수 자체가 치킨 사이즈만큼 다시 호출하게 합니다.
예를 들어 치킨 사이즈가 N이라면 N^N 수준의 시간복잡도를 가진 코드가 되게 됩니다.
이 때문에 시간초과가 나는 것 같습니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0





