2017-04-05 11 views

답변

4

솔루션의 문제는 당신이 삽입 작업은 "프로빙 선형"를 사용하지만, 당신이 그것을 검색하는 동일한 방법을 사용하지 않는 것입니다 :

이 내 프로그램입니다.

var hasharray [15]Item 

둘째, 내가이 계산 된 해시 인덱스 항목의 값을 확인하는 방법을 검색 변경할 것이며, 후 : - 모든

우선 대신 값의 전체 구조체를 유지하기 위해 밑줄 스토리지를 바꿀 것 여기를 참조하십시오

func retrieve(key string) { 
    index := hashmethod(key) 
    found := false 
    for !found { 
     item:= hasharray[index]; 
     if key == item.key { 
     found = true; 
     fmt.Println(index, item) 
     } else if index != size-1 { 
      index++ 
     } else { 
      index = 0 
     } 
    } 
} 

: https://play.golang.org/p/8JfTpbJcWx

을 충돌이 있다면 하나 그 반복 처리 항목 중 하나는 실제 항목을 찾을 수 있습니다