inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

섹션 7. 직접 구현하는 Set3

해결된 질문

236

권정익

작성한 질문수 60

0

여기에서 hashCode의 값이 선생님과 다르게 출력되는데 잘못된 게 맞나요?

문자 고유의 값이니까 같은 문자라면 어느 컴퓨터나 같은 hashCode가 출력되야 하는 게 맞는거죠??

public class MyHashSetV2Main2 {

    public static void main(String[] args) {
        Member hi = new Member("hi");
        Member jpa = new Member("JPA"); // 대문자 주의!
        Member java = new Member("java");
        Member spring = new Member("spring");

        System.out.println("hi.hashCode() = " + hi.hashCode());
        System.out.println("jpa.hashCode() = " + jpa.hashCode());
        System.out.println("java.hashCode() = " + java.hashCode());
        System.out.println("spring.hashCode() = " + spring.hashCode());

        MyHashSetV2 set = new MyHashSetV2(10);

        set.add(hi); // Member 타입의 인스턴스를 myHashSetV2에 넣음.
        set.add(jpa);
        set.add(java);
        set.add(spring);
        System.out.println("set = " + set);

        //검색
        Member searchValue = new Member("JPA");
        boolean result = set.contains(searchValue);
        System.out.println("hi.contains(" + searchValue + ") = " + result);

    }

       //출력 결과
       hi.hashCode() = 3329
       jpa.hashCode() = 73659
       java.hashCode() = 3254818
       spring.hashCode() = -895679987

 

 

 

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

답변 1

1

OMG

안녕하세요. 권정익님, 공식 서포터즈 OMG입니다.

저는 강의와 동일하게 출력되네요 😀

image

Member 클래스의 hashCode를 확인해보시겠어요?

image

감사합니다.

0

권정익

import collection.set.member.Member;

public class MyHashSetV2Main2 {

    public static void main(String[] args) {
        MyHashSetV2 set = new MyHashSetV2(10);
        Member hi = new Member("hi");
        Member jpa = new Member("JPA"); // 대문자 주의!
        Member java = new Member("java");
        Member spring = new Member("spring");

        System.out.println("hi.hashCode() = " + hi.hashCode());
        System.out.println("jpa.hashCode() = " + jpa.hashCode());
        System.out.println("java.hashCode() = " + java.hashCode());
        System.out.println("spring.hashCode() = " + spring.hashCode());

        set.add(hi); // Member 타입의 인스턴스를 myHashSetV2에 넣음.
        set.add(jpa);
        set.add(java);
        set.add(spring);
        System.out.println("set = " + set);

        //검색
        Member searchValue = new Member("JPA");
        boolean result = set.contains(searchValue);
        System.out.println("hi.contains(" + searchValue + ") = " + result);

    }
}
import java.util.Objects;

public class Member {

    private final String id;

    public Member(String id) {
        this.id = id;
    }

    public String getId() {
        return id;
    }

    @Override
    public boolean equals(Object object) {
        if (this == object) return true;
        if (object == null || getClass() != object.getClass()) return false;
        Member member = (Member) object;
        return Objects.equals(id, member.id);
    }

    @Override
    public int hashCode() {
        return Objects.hashCode(id);
    }
}
import java.util.Arrays;
import java.util.LinkedList;

public class MyHashSetV2 {

    static final int DEFAULT_INITIAL_CAPACITY = 16;

    private LinkedList<Object>[] buckets;
    private int size;
    private int capacity = DEFAULT_INITIAL_CAPACITY;

    public MyHashSetV2() {
        initBuckets();
    }

    public MyHashSetV2(int capacity) {
        this.capacity = capacity;
        initBuckets();
    }

    private void initBuckets() {
        buckets = new LinkedList[capacity];
        for (int i = 0; i < capacity; i++) {
            buckets[i] = new LinkedList<>();
        }
    }

    public boolean add(Object value) {
        LinkedList<Object> bucket = buckets[hashIndex(value)];
        if (bucket.contains(value)) {
            return false;
        }

        bucket.add(value);
        size++;
        return true;
    }

    public boolean remove(Object value) {
        LinkedList<Object> bucket = buckets[hashIndex(value)];
        boolean removeResult = bucket.remove(value);
        if (removeResult) {
            size--;
            return true;

        }

        return false;
    }

    public boolean contains(Object value) {
        int hashIndex = hashIndex(value);
        LinkedList<Object> bucket = buckets[hashIndex];
        return bucket.contains(value);

    }

    private int hashIndex(Object value) {
        return Math.abs(value.hashCode()) % capacity;
    }

    public int getSize() {
        return size;
    }

    @Override
    public String toString() {
        return "MyHashSetV2{" +
                "buckets=" + Arrays.toString(buckets) +
                ", size=" + size +
                ", capacity=" + capacity +
                '}';
    }
}

Member 클래스에 hashCode 오버라이딩도 새로 해봤는데 다르게 나옵니다 ㅠㅠ

0

OMG

Member클래스의 재정의한 hashCode() 의 구현 코드를 보면

@Override public int hashCode() { return Objects.hashCode(id); }

return Objects.hashCode()로 되어있습니다.

return Objects.hash()로(=강의코드) 확인해보시겠어요?

0

OMG

추가로 아래 링크도 참고해주세요 😀

https://www.inflearn.com/questions/1266776/generate로-hash-생성시-hash-와-hashcode

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

0

80

3

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

1

135

4

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

0

63

1

new T()가 안 되는 니유

0

102

1

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

0

98

2

자바 로드맵 선택 질문

0

111

2

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

0

177

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

78

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