해결된 질문
작성
·
197
0
안녕하세요 선생님,
http://boj.kr/748e160790bc4f178f9f9ec8afbd0054
테스트 케이스는 통과했지만, 시간 초과가 떴습니다. 선생님의 코드와 비교했을 때, 대충 제 코드의 'find' 함수에서 맵 순회 부분이 매우 비효율적이라는 것 정도를 짐작할 수 있었습니다. 다만, 확실히 짚고 넘어가고 싶어 이렇게 질문을 드립니다.
아래의 두 코드에서 시간복잡도 측면에서 어떤 차이가 있는지, 왜 선생님의 코드가 더 빠른지 정확히 알고싶습니다.
위가 제 코드이고, 아래가 선생님의 코드입니다.
1. 제 코드는 특정 값을 찾기위해 모든 맵을 순회하고 있는데, 선생님처럼 코드를 짜면 특정 값을 찾기위해 맵을 순회할 필요가 없나요?
2. 제 코드는 모든 맵을 순회하면서 맵의 first값, second 값 모두를 비교합니다. 이부분도 시간복잡도가 커질 수 있는 여지가 있나요?
혹시 시간초과가 난 다른 이유가 있다면 알려주시면 감사하겠습니다!
좋은 강의 늘 감사합니다:)
답변 1
0
안녕하세요 영수님 ㅎㅎ
1. 제 코드는 특정 값을 찾기위해 모든 맵을 순회하고 있는데, 선생님처럼 코드를 짜면 특정 값을 찾기위해 맵을 순회할 필요가 없나요?
>> 네 저건 순회가 아니라 해당 값 참조라 시간복잡도가 O(1)이 됩니다. 영수님 코드는 O(N)입니다.
2. 제 코드는 모든 맵을 순회하면서 맵의 first값, second 값 모두를 비교합니다. 이부분도 시간복잡도가 커질 수 있는 여지가 있나요?
>> 아뇨 그부분은 괜찮고 순회하는게 큽니다.
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
완벽히 이해했습니다! 감사합니다!