큐 구현 관련
68
작성한 질문수 7
현재 queue는 따로 구현하지 않고 shief() 메서드를 이용하고 있는데 queue 구현하지 않고 shief()로 했을 때 성능차이 크게 없을까요? 코딩 테스트 시에도 이렇게 진행해도 되는 지 여쭤보고 싶습니다.
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. 이민재님.
질문하신 내용에 대해 답변드리겠습니다. shift() 메서드를 사용하여 큐를 구현하는 경우와 큐를 별도로 구현하는 경우, 성능 차이가 있을 수 있습니다. 특히 규모가 큰 데이터를 다룰 때, shift() 메서드는 배열의 첫 요소를 제거하고 모든 뒤 요소를 한 칸씩 앞으로 이동시키기 때문에 시간 복잡도가 O(n)입니다.
성능 차이:
shift()메서드로 큐를 구현할 경우, 시간이 많이 소요됩니다. 특히, 반복적인shift()호출이 발생하면 성능 저하를 유발할 수 있습니다.
- 직접 큐를 링크드 리스트나 다른 자료구조로 구현할 경우, 삽입 및 삭제가 O(1) 시간에 가능하여 더 효율적입니다.
코딩 테스트 시:
- 코딩 테스트에서는 성능을 중요하게 여기기 때문에 특히 대량의 데이터가 다뤄질 경우, 직접 구현한 큐가 더 유리할 수 있습니다.
- 기본 제공 메서드인
shift()로 구현해도 무방할 수 있지만, 문제의 성격과 데이터 양에 따라 성능을 고려할 필요가 있습니다.
- 코딩 테스트에서는 성능을 중요하게 여기기 때문에 특히 대량의 데이터가 다뤄질 경우, 직접 구현한 큐가 더 유리할 수 있습니다.
큐를 구현하는 방법이나 성능 관련 문의는 이 게시물도 참고하시면 도움이 될 것입니다. 제가 추천드릴 수 있는 방법으로, 코딩 테스트 연습 문제를 풀어보시면서 두 방식 간의 성능 차이를 직접 경험해 보세요.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
3-F 채점 관련 질문
0
4
0
BFS, DFS 활용이 되는 상황에서의 방향성
0
8
2
counter01.html은 어디있을까요?
1
8
1
코딩살구클럽 승인
0
14
2
코딩살구클럽승인
0
12
2
존재하지 않는 일기 url입력 시 alert이 두 번 떠요
0
23
1
useState 직접 구현 부분에서 질문이 있습니다.
1
29
1
학습을 하고 블로그에 정리를 해도 괜찮을까요?
1
31
1
코딩살구클럽 승인
0
43
2
3-D 관련 질문
0
33
2
교재(3쇄)와 강의 내용 문의
0
31
2
코살구 회원가입 문의
0
38
2
강의노트 접속 불가
0
28
2
코살구 로그인 문제
0
60
2
생산 공정 최적화 (이분탐색) worst Case 수정
0
64
1
버블정렬
0
56
1
학습 방향성에 대한 문의
1
89
2
난이도 질문
0
103
2
강의 구현 코드
0
101
2
테스트 케이스 관련
0
80
1
연결리스트 뒤집기
0
80
2
공부방법 문의
0
91
1
알고리즘 개념에 대한 추천 자료문의
0
82
1
강의에 나온 selection 코드에 오류가 있습니다.
0
130
2





