inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

1-I

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

해결된 질문

259

김영수

작성한 질문수 9

0

안녕하세요 선생님,

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

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

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

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

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

 

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

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

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 영수님 ㅎㅎ

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

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

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

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

 


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

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

감사합니다.

강사 큰돌 올림.


0

김영수

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

코살구 로그인 문제

0

11

1

3-A 문제 풀이 관련 질문

0

32

2

2-O 질문 있습니다

0

31

2

2-T 문제에 관한 질문

0

29

2

코딩 살구 클럽 접속 및 사용방법 문의

0

44

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

59

2

코딩살구클럽 로그인문제

0

61

3

코딩 살구 클럽 로그인 문제

0

68

2

2-J 채점관련 질문

0

63

3

코딩 살구 클럽 Python 지원 가능 여부

0

72

1

살구클럽 아이디 없음 문제

0

73

1

1-O 코딩살구클럽 채점관련 질문

0

55

2

히든 테스트 케이스가 사라졌습니다

0

53

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

71

2

살구 클럽 채점 관련 문의(테스트 케이스)

0

65

2

1-H 문제 채점하기 오류

0

57

3

코딩살구클럽 2주차 2-L 문제 채점하기 오류

0

51

2

살구 클럽 채점 관련 문의

0

61

2

코딩 살구 클럽 실전 세션

0

56

2

코딩살구클럽 채점 관련 질문

0

49

2

코딩살구클럽 컴파일에러

0

78

2

5-B

0

49

2

4 - A

0

57

2

코딩살구클럽 입장이 안됩니다

0

147

2