inflearn logo
강의

Course

Instructor

10-Week Completion C++ Coding Test | Algorithm Coding Test

3-L

3 - L 시간 초과

126

zart

59 asked

0

안녕하세요 큰돌님! 오랜만에 질문드립니다!

http://boj.kr/ffa51980cf4e43d78718101ba7fea04f
위 코드는 시간 초과 없이 맞는 코드고
http://boj.kr/e3c9471b62724bd9819cc038d6127c47
위 코드는 시간 초과가 64%에서 생기는 코드입니다

 

로직적인 차이도 없는 거 같고 빠르다 해도 이진 트리 map이 아닌 해시값 기반인 unordered_map이 더 빠를 거 같은데, 왜 시간 초과가 나는 지 궁금해서 질문드립니다!

c++ 코딩-테스트

Answer 3

0

zart

답변 감사합니다!!! 딱 그 테케에 걸렸나보네요 감사해요!

0

kundol

안녕하세요 자르트님 ㅎㅎ

unordered_map의 최악의 시간복잡도는 O(N)입니다. 평균적으로는 O(1)이지만 최악의 경우에 걸려서 -> 시간초과가 난 것 같습니다.

image.png

이부분은 참고로 교안내 앞의 부분 참고 부탁드립니다.


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

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

감사합니다.

강사 큰돌 올림.


 

 

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다.

자르트님께서 올려주신 문제에 대해 살펴보았습니다. C++의 unordered_map은 평균적으로 O(1)의 시간 복잡도로 동작하지만, 최악의 경우 O(N)의 시간 복잡도를 가질 수 있기 때문에, 특정한 경우에서 해시 충돌이 발생하여 시간 초과가 발생할 수 있습니다.

해당 상황은 다음과 같은 조건에서 발생할 수 있습니다:

  1. 데이터 분포: 해시 함수가 데이터의 분포에 적절하지 않고 많은 충돌이 발생하는 경우. 이 경우 unordered_map의 동작이 비효율적일 수 있습니다.

  2. 연산 횟수 누적: 반복적으로 unordered_map을 사용하는 경우에 여러 번의 O(N) 연산이 누적되어 전체 알고리즘의 시간 복잡도가 큰 영향을 받을 수 있습니다.

관련된 다른 질문과 답변을 참고하려면 아래의 링크를 확인해보세요:

이해를 돕기 위한 이미지도 있었는데, 기본적으로 unordered_map에서의 해시 충돌로 인한 O(N) 문제 설명이 포함되어 있었던 것 같습니다.

추가적인 사항으로는, 코드에서 unordered_map 대신에 map을 사용하여 루프를 개선할 수 있거나, 조금 더 효율적인 해시 함수를 구현해보는 것도 방법이 될 수 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

2주차 개념#12 트리 순회

0

8

2

백준사이트가 종료된다고 합니다.

0

200

2

백준 서비스 종료

9

633

1

sk 하이닉스 코테 대비

0

346

2

3-G 최댓값 질문

0

46

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

77

2

3-I 코드 질문드립니다.

0

59

2

3-N 질문 있습니다.

0

63

2

학습방법

0

98

2

4-H 질문 있습니다 (코드 리뷰)

0

65

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

161

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

68

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

62

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

48

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

66

2

함수별 시간복잡도

0

71

2

3-h 질문입니다.

0

47

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

51

2

1-I 문제 질문 드립니다.

0

74

2

2-P 질문입니다.

0

55

1

mac에서 시작하기 관련

0

86

2

5-Q 질문

0

62

2

풀이 코드 질문

0

62

2

맞왜틀

0

67

2