• 카테고리

    질문 & 답변
  • 세부 분야

    알고리즘 · 자료구조

  • 해결 여부

    해결됨

시간초과 관련 질문 드립니다.

24.01.28 23:04 작성 조회수 122

0

안녕하세요 선생님,

http://boj.kr/748e160790bc4f178f9f9ec8afbd0054
테스트 케이스는 통과했지만, 시간 초과가 떴습니다. 선생님의 코드와 비교했을 때, 대충 제 코드의 'find' 함수에서 맵 순회 부분이 매우 비효율적이라는 것 정도를 짐작할 수 있었습니다. 다만, 확실히 짚고 넘어가고 싶어 이렇게 질문을 드립니다.

아래의 두 코드에서 시간복잡도 측면에서 어떤 차이가 있는지, 왜 선생님의 코드가 더 빠른지 정확히 알고싶습니다.

스크린샷 2024-01-28 225010.png스크린샷 2024-01-28 225145.png

위가 제 코드이고, 아래가 선생님의 코드입니다.
1. 제 코드는 특정 값을 찾기위해 모든 맵을 순회하고 있는데, 선생님처럼 코드를 짜면 특정 값을 찾기위해 맵을 순회할 필요가 없나요?

2. 제 코드는 모든 맵을 순회하면서 맵의 first값, second 값 모두를 비교합니다. 이부분도 시간복잡도가 커질 수 있는 여지가 있나요?

 

  1. 혹시 시간초과가 난 다른 이유가 있다면 알려주시면 감사하겠습니다!

    좋은 강의 늘 감사합니다:)

답변 1

답변을 작성해보세요.

0

안녕하세요 영수님 ㅎㅎ

1. 제 코드는 특정 값을 찾기위해 모든 맵을 순회하고 있는데, 선생님처럼 코드를 짜면 특정 값을 찾기위해 맵을 순회할 필요가 없나요?

>> 네 저건 순회가 아니라 해당 값 참조라 시간복잡도가 O(1)이 됩니다. 영수님 코드는 O(N)입니다.

2. 제 코드는 모든 맵을 순회하면서 맵의 first값, second 값 모두를 비교합니다. 이부분도 시간복잡도가 커질 수 있는 여지가 있나요?

>> 아뇨 그부분은 괜찮고 순회하는게 큽니다.

 


또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


김영수님의 프로필

김영수

질문자

2024.01.29

완벽히 이해했습니다! 감사합니다!