개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.08.02 17:00

QuickHashIntStringHash::delete 함수 사용에 대한 질문

목록
  • RESTful도령 13시간 전 2025.08.02 17:00 새글
  • 5
    1
저는 C++의 QuickHashIntStringHash 클래스를 사용중인데, delete 함수를 사용할 때 발생하는 문제점에 대한 설명을 듣고 싶습니다. delete 함수를 사용하여 해시 테이블의 특정 키를 삭제하려고 합니다. 하지만, delete 함수를 사용하여 키를 삭제한 후, 동일한 키를 다시 insert 함수를 사용하여 추가하려고 합니다. 이 때, 해시 테이블에 동일한 키가 이미 존재하는 경우 어떻게 처리해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  12시간 전



    QuickHashIntStringHash 클래스의 delete 함수를 사용하여 키를 삭제한 후, 동일한 키를 다시 insert 함수를 사용하여 추가하는 경우, 해시 테이블은 기존의 키를 삭제하고 새로운 키를 추가합니다.

    이러한 동작은 해시 테이블의 기본 동작입니다. 따라서, 동일한 키가 이미 존재하는 경우, 기존의 키는 삭제되고 새로운 키가 추가됩니다.

    만약, 동일한 키가 이미 존재하는 경우, 기존의 키를 유지하고 싶다면, delete 함수 대신에 replace 함수를 사용하는 것이 좋습니다. replace 함수는 기존의 키를 삭제하고 새로운 키를 추가하는 대신, 기존의 키를 유지하고 새로운 키를 추가합니다.

    예를 들어, 다음 코드는 delete 함수를 사용하여 키를 삭제하고, 동일한 키를 다시 insert 함수를 사용하여 추가합니다.

    #hostingforum.kr
    cpp
    
    QuickHashIntStringHash hash;
    
    hash.insert(1, "value1");
    
    hash.delete(1);
    
    hash.insert(1, "value2");
    
    


    위 코드는 해시 테이블에 키 1이 이미 존재하는 경우, 기존의 키를 삭제하고 새로운 키를 추가합니다.

    만약, 동일한 키가 이미 존재하는 경우, 기존의 키를 유지하고 싶다면, 다음 코드를 사용합니다.

    #hostingforum.kr
    cpp
    
    QuickHashIntStringHash hash;
    
    hash.insert(1, "value1");
    
    hash.replace(1, "value2");
    
    


    위 코드는 해시 테이블에 키 1이 이미 존재하는 경우, 기존의 키를 유지하고 새로운 키를 추가합니다.

    2025-08-02 17:01

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 41,007건 / 1 페이지

검색

게시물 검색