inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

김영한의 실전 자바 - 중급 2편

해시 알고리즘6 - 해시 충돌 구현

LinkedList의 for-each 동작 방식이 궁금합니다.

106

주성

작성한 질문수 3

0

본 강의 약 10분 쯤에 나오는 코드
private static boolean contains(LinkedList<Integer>[] buckets, int searchValue) { int hashIndex = hashIndex(searchValue); LinkedList<Integer> bucket = buckets[hashIndex]; for (Integer integer : bucket) { if (integer == searchValue) { return true; } } return false; }
이 부분에서 배열은 각 인덱스의 요소를 하나씩 꺼내는데 LinkedList는 어떤식으로 for-each문을 사용하는지 궁금합니다.

java 객체지향 코딩-테스트 알고리즘

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.
주성님께서 질문하신 LinkedList의 for-each 동작 방식에 대해 설명 드리겠습니다.

Java의 LinkedList는 내부적으로 이중 연결 리스트(Doubly Linked List) 구조로 구현되어 있습니다. for-each문을 사용할 때, LinkedListIterator가 사용됩니다. Iterator는 리스트의 처음부터 끝까지 순회하며 각 노드를 방문합니다. 구체적인 동작 방식은 다음과 같습니다:

  1. Iterator 생성: for-each 문이 시작되면 LinkedListiterator() 메소드가 호출되어 Iterator 객체가 생성됩니다.

  2. 다음 요소 확인 및 방문: Iterator 객체는 내부적으로 커서(cursor)를 유지하여 현재 위치를 추적합니다. hasNext() 메소드를 통해 더 방문할 요소가 있는지 확인하고, next() 메소드를 통해 현재 커서 위치의 요소를 반환하고 커서를 다음 요소로 이동시킵니다.

  3. 반복문 종료: 리스트의 끝에 도달하면 hasNext()false를 반환하여 반복이 종료됩니다.

for-each 문은 Iterator로 직접 순회를 처리하기 때문에 개발자가 복잡한 반복문을 작성할 필요 없이 모든 요소를 쉽게 탐색할 수 있게 합니다.

추가로 참고하실 수 있는 자료나 코드 예제를 찾으시려면 LinkedList와 Iterator를 확인해 보시길 권장드립니다.

혹시 더 궁금한 점이 있으시면 언제든지 질문해 주세요!

제네릭 타입 매개변수 제한과 관련한 문의입니다.

0

80

3

강의가 좀 버겁다 느껴질 때 학습방법 문의

1

135

4

제네릭 반환값 및 파라미터 선언 방식의 변화 <T> T

0

62

1

new T()가 안 되는 니유

0

102

1

안녕하세요, 문제와 실행 결과가 다른 부분이 있어 제보드립니다.

0

98

2

자바 로드맵 선택 질문

0

111

2

실전 자바 중급 - 2편 후 추천 강의

0

176

2

실프로젝트에서 Java25버전 사용

0

121

1

Arrays.sort

0

68

1

블로그 작성 시, 저작권 문제에 대하여

0

166

1

중급2편 56강의 bucket.add(value); 메서드가 이해가 안됩니다.

0

94

3

pop()과 poll()의 차이

0

94

1

특정 index의 노드 조회하기 질문

0

66

2

List.of() 비어있는 불변 리스트 생성

0

81

2

문제2: 개 타입 반환

0

56

2

[리뷰] 중급2편까지 겨우 완강 했습니다.

0

114

2

문제와 풀이1 Ex2와 Ex3

0

65

2

노드 삭제시 노드 null값으로 초기화

0

77

2

강의영상에 대한 질문

0

57

1

타입 매개변수 제한

0

59

1

compareTo

0

68

1

직접 구현하는 연결리스트 3 - 추가 부분 질문있습니다

0

99

3

섹션 8-58 equals and hashcode 에서 코드가 다르게 생성됨

0

70

2

퀴즈 오류 관련 문의

0

109

1