inflearn logo
강의

講義

知識共有

図で簡単に学ぶデータ構造とアルゴリズム(基本編)

ハッシュテーブル - 実装

[수업질문] HashTable 구현 질문 javascript->c++

解決済みの質問

137

ppatabox

投稿した質問数 9

1

HashTable클래스내 get함수에
C++로 학습하고 있는데..
currentNode는 HashData*의 정보를 가져와서 currentNode를 구현한 것인가요?

아니면 int 로 그냥 들어간건가요?
만약 int 이면 DoublyLinkedList에 존재하는 data를
int currentNode = arr[this->hashFunction(key)].head->data;

이렇게 넘겨줘야하는데.

만약 int형이 아니면...
while문에 들어간 currentNode.data.value는 어디서 나온건지 모르겠네요. .

DoublyLinkedList를 혹시 수정을 하신건지..흠..

let이 그냥 자동으로 얘 이런거니까 자료형 알아서 만들어 느낌같은데.. 너무.. 헷갈리네요..

알고리즘 수업질문 인프런 감자

回答 2

1

gamja5

안녕하세요 빠타박스님!

해쉬테이블의 arr마다 DoublyLinkedList를 생성했기 때문에

let currentNode = this.arr[this.hashFunction(key)].head // head는 Node객체

는 DoublyLinkedList의 Node 객체입니다.

그리고 Node객체의 data에 저장된 값은 HashData입니다.

궁금증이 해결되셨나요?😊

0

ppatabox

감사합니다 궁금증이 해결되었습니다!

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 빠타박스님께서 질문하신 HashTable과 DoublyLinkedList 관련된 내용에 대해서 도움을 드리도록 하겠습니다. C++로 구현하시면서 JavaScript의 변수 선언 방식과 비교하시느라 조금 혼란스러우셨던 것 같습니다.

  1. currentNode의 자료형: C++에서는 명시적으로 자료형을 선언해야 하기 때문에 currentNode가 무엇을 가리키는지에 따라 자료형이 달라집니다. 만약 currentNodeHashData* 형식이라면 포인터로 사용될 것이고, 그렇지 않으면 일반적인 데이터 타입일 수 있습니다. JavaScript에서는 타입을 명시하지 않아도 자동으로 인식되지만, C++에서는 명확하게 선언해야 합니다.

  2. DoublyLinkedList와 Node: C++에서는 DoublyLinkedList의 노드가 가지고 있는 데이터 타입에 따라 currentNode가 어떻게 선언되는지가 달라질 수 있습니다. 만약 노드가 HashData라는 구조체나 클래스를 가리키고 있다면, currentNode 역시 그 타입으로 선언해야 합니다.

  3. while문의 currentNode.data.value: 이 부분은 currentNode가 객체일 때 객체 내의 특정 값을 참조하는 방식입니다. DoublyLinkedList의 Node가 어떤 자료를 가지고 있는지 확인하고, 그에 따라 .data 내지는 .value 같은 멤버 접근 연산자를 활용하게 됩니다.

  4. C++ 코드 수정 여부: DoublyLinkedList나 HashTable 구조를 변경하셨는지에 따라 로직이 달라질 수 있습니다. 이러한 클래스와 구조체도 C++에서 명시적으로 정의되어야 하며, 필요에 따라 데이터를 저장하거나 접근하는 방법도 달라집니다.

관련된 기존 질문과 답변으로 C++로 구현한 Linked List 접근 문제를 참고하시면 도움이 될 수 있습니다. 이 게시물들은 변수 타입과 데이터 접근 문제에 대해 보다 자세히 설명하고 있으니 확인해 보시기 바랍니다.

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

큐의 마지막 데이터가 head에 위치해야 하는 이유가 궁금합니다.

0

71

2

이중연결 리스트 데이터 삭제시 질문이 있습니다.

1

61

2

자바스크립트 배열은 동적이 아닌가요?

1

85

2

자바스크립트 배열

0

75

2

코테에서 링크리스트 자료구조를 사용해야 하면, 이번 강의에서 구현한 메서드들도 모두 직접 구현하면 되나요?/

0

150

2

공부 방식 질문 드립니다.

1

115

2

메모이제이션과 타뷸레이션 관련해서 질문드립니다.

1

166

2

병합정렬에서 질문이 있습니다.

2

141

1

병합정렬 질문 있습니다.

1

136

5

데이터 삽입, 삭제 함수 오류 범위 설정

0

156

2

해시 테이블에서 질문이 잇습니다.

2

127

2

시간복잡도 계산 시 1회 연산당 연산량은 왜 고려하지 않는 건가요?

1

147

2

터미널 설정

0

113

2

2:13분 관련 질문입니다

0

89

1

8:47초경부터 9:00초까지 질문입니다.

1

133

2

tail을 삭제하는 경우에 관련해서 질문이 있습니다.

0

106

1

2:36초 head 위치가?

1

109

2

환경구축강의 중 터미널 파일 실행오류

0

160

2

4:58 이중for문 질문있습니다.

0

103

1

hanoi함수 처음 호출에 대해서 여쭤봅니다.

1

129

2

해쉬테이블 데이터 관련해서 질문있습니다.

0

147

2

자바스크립트 Map과 어떤 차이가 있나요??

0

202

2

질문이있습니다.

0

102

1

2번째 복습 스터디📖 를 진행하고 스터디원분들과 나눈 질문들 입니다.(자료구조와 알고리즘)

1

146

2