CS/Python
[자료구조] 해시
Cori
2021. 9. 27. 23:57
해시
0) 정의
-> 데이터를 다루는 기법 중 하나로, 검색과 저장에 아주 유용한 구조이다. key-value 쌍으로 데이터를 저장함
1) 해시함수란 ?
-> 임의의 길이를 갖는 메시지를 입력받아 고정된 길이의 해시값을 출력하는 함수
2) 해시 구현 방법
· 딕셔너리에 삽입
hash = dict()
hash[1] = 'apple'
hash['banana'] = 3
hash[(4, 5)] = [1, 2, 3]
hash[10] = dict({1: 'a', 2: 'b'})
위와 같은 형태로 해시 함수를 사용할 수 있지만, 집합과 배열은 해시 함수의 키 값으로 사용할 수 없다. (인덱스로 변환 불가)
ex) hash({3, 5}), hash([3, 5]) -> 사용 x
· 딕셔너리 값 추출
hash.pop(1) # 'melon'
hash.pop('banana') # 10
hash.pop((4, 5)) # [1, 2, 3]
hash.pop(10) # {1: 'a', 2: 'b'}
· 딕셔너리 값 삭제
del hash[1]
del hash['banana']
del hash[(4, 5)]
del hash[10]
· 딕셔너리 루프 (keys, values, items)
for k in hash.keys():
print(k)
for v in hash.values():
print(v)
for k, v in has.items():
print(k, v)
· 딕셔너리 정렬 -> sorted()를 통해 정렬하며, 항상 list 타입 반환
hash = dict({1:10, 3:12, 5:7, 7:6, 4:5})
# 오름차순 정렬
sorted(hash.keys(), key = lambda x: x)
sorted(hash.values(), key = lambda x: x)
sorted(hash.items(), key = lambda x: x)
# 내림차순 정렬
sorted(hash.keys(), key = lambda x: -x)
sorted(hash.values(), key = lambda x: -x)
내림차순 정렬시에 key, values()와 달리 items()을 사용할 경우 오류를 반환하는데, 이는 items()의 반환 값이 튜플이기 때문에, 정렬 x
(튜플에는 - 값을 줄 수 x)
∴ 다음과 같이 정렬 할 수 있음
sorted(hash.items(), key = lambda x: (x[0], x[1])) # key 오름차순, value 오름차순
sorted(hash.items(), key = lambda x: (-x[0], x[1]) # key 내림차순, value 오름차순
sorted(hash.items(), key = lambda x: (x[1], [0]) # value 오름차순, key 오름차순