인프런 커뮤니티 질문&답변

김영수님의 프로필 이미지
김영수

작성한 질문수

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

1-I

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

해결된 질문

작성

·

197

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점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


김영수님의 프로필 이미지
김영수
질문자

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

김영수님의 프로필 이미지
김영수

작성한 질문수

질문하기